For More Udemy Free Courses >>> https://freetutorials.us/
For more Lynda and other Courses >>> https://www.freecoursesonline.me/
Forum for discussion >>> https://1hack.us/
By : Alex Guerrieri
Released : July 5, 2019
Pages : 458 pages
Format : EPUB
Source : https://www.packtpub.com/eu/application-development/hands-systems-programming-go
Explore the fundamentals of systems programming starting from kernel API and filesystem to network programming and process communications
Details
ISBN 9781789804072
Reading Length 13 hours 34 minutes
Table of Contents
• An Introduction to System Programming
• Unix OS Components
• An Overview of Go
• Working with the Filesystem
• Handling Streams
• Building Pseudo-Terminals
• Handling Processes and Daemons
• Exit Codes, Signals, and Pipes
• Network Programming
• Data Encoding Using Go
• Dealing with Channels and Goroutines
• Synchronization with sync and atomic
• Coordination Using Context
• Implementing Concurrency Patterns
• Using Reflection
• Using CGO
Learn
• Explore concepts of system programming using Go and concurrency
• Gain insights into Golang's internals, memory models and allocation
• Familiarize yourself with the filesystem and IO streams in general
• Handle and control processes and daemons' lifetime via signals and pipes
• Communicate with other applications effectively using a network
• Use various encoding formats to serialize complex data structures
• Become well-versed in concurrency with channels, goroutines, and sync
• Use concurrency patterns to build robust and performant system applications
About
System software and applications were largely created using low-level languages such as C or C++. Go is a modern language that combines simplicity, concurrency, and performance, making it a good alternative for building system applications for Linux and macOS.
This Go book introduces Unix and systems programming to help you understand the components the OS has to offer, ranging from the kernel API to the filesystem. You'll then familiarize yourself with Go and its specifications. You'll also learn how to optimize input and output operations with files and streams of data, which are useful tools in building pseudo-terminal applications. You'll gain insights into how processes communicate with each other, and learn about processes and daemon control using signals, pipes, and exit codes. This book will also enable you to understand how to use network communication using various protocols, including TCP and HTTP. As you advance, you'll focus on Go's best feature - concurrency, which will help you handle communication with channels and goroutines, other concurrency tools to synchronize shared resources, and the context package to write elegant applications.
By the end of this book, you will have learned how to build concurrent system applications using Go
Features:
• Learn how to write Unix and Linux system code in Golang v1.12
• Perform inter-process communication using pipes, message queues, shared memory, and semaphores
• Explore modern Go features such as goroutines and channels that facilitate systems programming
Author(s)
Alex Guerrieri is a software developer who specializes in backend and distributed systems. Go has been his favorite tool for the job since first using it in 2013. He holds a degree in computer science engineering and has been working in the field for more than 6 years. Originally from Italy, where he completed his studies and started his career as a full-stack developer, he now lives in Spain, where he previously worked in two start-ups—source{d} and Cabify. He is now working for three companies—as a software crafter for BBVA, one of the biggest Spanish banks; as a software architect for Security First, London, a company focusing on digital and physical security; and as a cofounder of DauMau, the company behind Vidsey, software that generates videos in a procedural manner.