Nyd den ubegrænsede adgang til tusindvis af spændende e- og lydbøger - helt gratis
Fakta
Explore the fundamentals of systems programming starting from kernel API and filesystem to network programming and process communications
Key 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
•
Book Description
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, and 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 helping 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
What you will 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
Who this book is for
If you are a developer who wants to learn system programming with Go, this book is for you. Although no knowledge of Unix and Linux system programming is necessary, intermediate knowledge of Go will help you understand the concepts covered in the book
© 2019 Packt Publishing (E-bog): 9781789803365
Release date
E-bog: 5. juli 2019
Tags
Over 600.000 titler
Download og nyd titler offline
Eksklusive titler + Mofibo Originals
Børnevenligt miljø (Kids Mode)
Det er nemt at opsige når som helst
For dig som vil prøve Mofibo.
1 konto
20 timer/måned
Eksklusivt indhold hver uge
Fri lytning til podcasts
Gem ubrugt tid
Ingen binding
For dig som lytter og læser ofte.
1 konto
100 timer/måned
Eksklusivt indhold hver uge
Fri lytning til podcasts
Ingen binding
For dig som lytter og læser ubegrænset.
1 konto
Ubegrænset adgang
Eksklusivt indhold hver uge
Fri lytning til podcasts
Ingen binding
For dig som ønsker at dele historier med familien.
2-6 konti
100 timer/måned pr. konto
Fri lytning til podcasts
Kun 39 kr. pr. ekstra konto
Ingen binding
2 konti
179 kr. /månedDansk
Danmark