[ No Description ]



 



SGD 54.99

Key FeaturesA highly practical guide filled with numerous examples unleashing the power of design patterns with Go.Discover an introduction of the CSP concurrency model by explaining GoRoutines and channels.Get a full explanation, including comprehensive text and examples, of all known GoF design patterns in Go.Book DescriptionGo is a multi-paradigm programming language that has built-in facilities to create concurrent applications. Design patterns allow developers to efficiently address common problems faced during developing applications.Go Design Patterns will provide readers with a reference point to software design patterns and CSP concurrency design patterns to help them build applications in a more idiomatic, robust, and convenient way in Go.The book starts with a brief introduction to Go programming essentials and quickly moves on to explain the idea behind the creation of design patterns and how they appeared in the 90s as a common language between developers to solve common tasks in object-oriented programming languages. You will then learn how to apply the 23 Gang of Four (GoF) design patterns in Go and also learn about CSP concurrency patterns, the killer feature in Go that has helped Google develop software to maintain thousands of servers.With all of this the book will enable you to understand and apply design patterns in an idiomatic way that will produce concise, readable, and maintainable software.What you will learnAll basic syntax and tools needed to start coding in GoEncapsulate the creation of complex objects in an idiomatic way in GoCreate unique instances that cannot be duplicated within a programUnderstand the importance of object encapsulation to provide clarity and maintainabilityPrepare cost-effective actions so that different parts of the program arent affected by expensive tasksDeal with channels and GoRoutines within the Go context to build concurrent application in Go in an idiomatic wayAbout the AuthorMario Castro Contreras is a software engineer who has specialized in distributed systems and big data solutions. He works as a site reliability engineer, and now he is focused on containerized solutions and apps using most of Google Cloud suite; especially, Kubernetes. He has a wide experience in systems and solutions integration, and he has written many scalable and reliable 12 factor apps using Go and Docker. He has designed Big Data architectures for financial services and media, and he has written data processing pipelines using event-driven architectures written purely in Go. He is also very active in the open source community, and you can find him on his GitHub account with the username sayden. In the past, he has also written mobile applications and backends in Java.Mario is passionate about programming languages, and he found the best balance between fun and productivity in Go; however, recently, he enjoys writing in Rust and embedded systems in C. He is also passionate about road cycling and winter sports.Table of ContentsReady... Steady... Go!Creational Patterns - Singleton, Builder, Factory, Prototype, and Abstract Factory Design PatternsStructural Patterns - Composite, Adapter, and Bridge Design PatternsStructural Patterns - Proxy, Facade, Decorator, and Flyweight Design PatternsBehavioral Patterns - Strategy, Chain of Responsibility, and Command Design PatternsBehavioral Patterns - Template, Memento, and Interpreter Design PatternsBehavioral Patterns - Visitor, State, Mediator, and Observer Design PatternsIntroduction to Gos ConcurrencyConcurrency Patterns - Barrier, Future, and Pipeline Design PatternsConcurrency Patterns - Workers Pool and Publish/Subscriber Design Patterns
view book