Free Download System Programming Essentials with Go: System calls, networking, efficiency, and security practices with practical projects in Golang by Alex Rios
English | June 28, 2024 | ISBN: 1837634130 | 408 pages | EPUB | 2.08 Mb
Go beyond web development to learn system programming, building secure, concurrent, and efficient applications with Go’s unique system programming capabilities
Key FeaturesGet a deep understanding of how Go simplifies system-level memory management and concurrencyGain expert guidance on essential topics like file operations, process management, and network programmingLearn cross-platform system programming and how to build applications that interact directly with the OSBook Description
Alex Rios, a seasoned Go developer and active community builder, shares his 15 years of expertise in designing large-scale systems through this book. It masterfully cuts through complexity, enabling you to build efficient and secure applications with Go’s streamlined syntax and powerful concurrency features.
In this book, you’ll learn how Go, unlike traditional system programming languages (C/C++), lets you focus on the problem by prioritizing readability and elevating developer experience with features like automatic garbage collection and built-in concurrency primitives, which remove the burden of low-level memory management and intricate synchronization.
Through hands-on projects, you’ll master core concepts like file I/O, process management, and inter-process communication to automate tasks and interact with your system efficiently. You’ll delve into network programming in Go, equipping yourself with the skills to build robust, distributed applications. This book goes beyond the basics by exploring modern practices like logging and tracing for comprehensive application monitoring, and advance to distributed system design using Go to prepare you to tackle complex architectures.
By the end of this book, you’ll emerge as a confident Go system programmer, ready to craft high-performance, secure applications for the modern world.
What you will learnUnderstand the fundamentals of system programming using GoGrasp the concepts of goroutines, channels, data races, and managing concurrency in GoManage file operations and inter-process communication (IPC)Handle USB drives and Bluetooth devices and monitor peripheral events for hardware automationFamiliarize yourself with the basics of network programming and its application in GoImplement logging, tracing, and other telemetry practicesConstruct distributed cache and approach distributed systems using GoWho this book is for
This book is for software engineers looking to expand their understanding of system programming concepts. Professionals with a coding foundation seeking profound knowledge of system-level operations will also greatly benefit. Additionally, individuals interested in advancing their system programming skills, whether experienced developers or those transitioning to the field, will find this book indispensable.
Table of ContentsWhy Go?Refreshing Concurrency and ParallelismUnderstanding System CallsFile and Directory OperationsWorking with System EventsUnderstanding Pipes in Inter-Process CommunicationHardware AutomationMemory ManagementAnalysing PerformanceNetworkingTelemetryDistributing Your AppsCapstone Project – Distributed CacheEffective Coding PracticesStay Sharp with System Programming
[b]Feel Free to contact me for book requests, informations or feedbacks.