Book Image

Concurrency with Modern C++

By : Rainer Grimm
Book Image

Concurrency with Modern C++

By: Rainer Grimm

Overview of this book

C++11 is the first C++ standard that deals with concurrency. The story goes on with C++17 and will continue with C++20/23. Concurrency with Modern C++ is a practical guide that gets you to grips with concurrent programming in Modern C++. Starting with the C++ memory model and using many ready-to-run code examples, the book covers everything you need to improve your C++ multithreading skills. You'll gain insight into different design patterns. You'll also uncover the general consideration you have to keep in mind while designing a concurrent data structure. The final chapter in the book talks extensively about the common pitfalls of concurrent programming and ways to overcome these hurdles. By the end of the book, you'll have the skills to build your own concurrent programs and enhance your knowledge base.
Table of Contents (19 chapters)
Free Chapter
1
Reader Testimonials
19
Index

The Contract

This contract is between the programmer and the system. The system consists of the compiler that generates machine code, the processor that executes the machine code and includes the different caches that store the state of the program. Each of the participants wants to optimise its part. For example, the compiler uses registers or modifies loops; the processor performs out of order execution or branch prediction; the caches applies prefetching of instructions or buffering of values. The result is - in the good case - a well-defined executable, that is fully optimised for the hardware platform. To be precise, there is not only a single contract, but a fine-grained set of contracts. Or to say it differently: the weaker the rules are that the programmer has to follow, the more potential there is for the system to generate a highly optimised executable.

There is a rule of thumb. The stronger the contract, the fewer liberties for the system to generate an optimised executable...