About this item
Highlights
- This easy-to-read, hands-on guide demystifies concurrency concepts like threading, asynchronous programming, and parallel processing in any language.
- About the Author: Kirill Bobrov is a software engineer.
- 304 Pages
- Computers + Internet, Programming Languages
Description
About the Book
Grokking Concurrency is an easy-to-read, hands-on guide that that will help you leverage multiple cores and terabytes of data and excel with high loads even after hardware and software failures. With clear explanations of core concepts, interesting illustrations, and examples, this is the ideal textbook to help you demystify concurrency concepts.
Book Synopsis
This easy-to-read, hands-on guide demystifies concurrency concepts like threading, asynchronous programming, and parallel processing in any language. Perplexed by concurrency? Don't be. This engaging, fully-illustrated beginner's guide gets you writing the kind of high-performance code your apps deserve. Inside, you'll find thorough explanations of concurrency's core concepts--all explained with interesting illustrations, insightful examples, and detailed techniques you can apply to your own projects. In Grokking Concurrency you will:- Get up to speed with the core concepts of concurrency, asynchrony, and parallel programming
- Learn the strengths and weaknesses of different hardware architectures
- Improve the sequential performance characteristics of your software
- Solve common problems for concurrent programming
- Compose patterns into a series of practices for writing scalable systems
- Write and implement concurrency systems that scale to any size
Discover effective concurrency practices that will help you leverage multiple cores, excel with high loads, handle terabytes of data, and continue working after hardware and software failures. The core concepts in this guide will remain eternally relevant, whether you're building web apps, IoT systems, or handling big data. Purchase of the print book includes a free eBook in PDF and ePub formats from Manning Publications. About the technology Concurrency is an approach to running computer programs efficiently by separating them into tasks that can execute independently. This basic idea makes it possible to accelerate game graphics, train large AI models, rapidly scale web applications, streamline big data processing, and much more. Concurrency can get complicated, so this book gets you started gently with interesting examples, entertaining illustrations, and easy-to-follow Python code. About the book Grokking Concurrency is a perfectly paced introduction to the fundamentals of concurrent, parallel, and asynchronous programming. In it, you'll learn the practices you'll need to program multicore processors, GPUs, and other high-performance systems. Author Kirill Bobrov skips the math, jargon, and academic language and concentrates on clear, plain-English explanations. What's inside
- Writing and running concurrent programs
- Patterns for performance, scalability, and resilience
- Choosing the right hardware
- Asynchronous communication
About the reader Examples in Python. No prior experience with concurrency or high-performance computing required. About the author Kirill Bobrov is a software engineer with a passion for data engineering. Table of Contents Part 1 The Octopus Orchestra: Introduction to a Symphony of Concurrency
1 Introducing concurrency
2 Serial and parallel execution
3 How computers work
4 Building blocks of concurrency
5 Interprocess communication
Part 2 the Many Tentacles of Concurrency: Multitasking, Decomposition,
and Synchronization
6 Multitasking
7 Decomposition
8 Solving concurrency problems: Race conditions and synchronization
9 Solving concurrency problems: Deadlocks and starvation
Part 3 Asynchronous Octopuses: a Pizza-making Tale of Concurrency
10 Nonblocking I/O
11 Event-based concurrency
12 Asynchronous communication
13 Writing concurrent applications
From the Back Cover
Grokking Concurrency is a friendly guide for any developer, perplexed about concurrency. It focuses on the fundamentals, explaining concurrent programming and asynchrony in a math and jargon-free way. Fun illustrations and diagrams make complex concepts easy to understand. The book presents the most important concurrency features with examples in the accessible Python language. No matter what language you use, you'll learn best practices for implementing concurrency.
About the readerFor readers who know the basics of programming. Examples are in Python.
Review Quotes
Don't be afraid about concurrency, learn from Grokking Concurrency!
Eddu Melendez
This book is a model of clarity. It clearly puts back not-so-well-known concepts in context.
Luc Rogge
The Manning Grokking series has a well deserved good reputation and this book will not let the series down.
Patrick Regan
About the Author
Kirill Bobrov is a software engineer. His experience includes the development and design of high-load web applications. He now focuses on data engineering practices for companies around the world.