Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Asynchronous Programming with C++

You're reading from   Asynchronous Programming with C++ Build blazing-fast software with multithreading and asynchronous programming for ultimate efficiency

Arrow left icon
Product type Paperback
Published in Nov 2024
Publisher Packt
ISBN-13 9781835884249
Length 424 pages
Edition 1st Edition
Languages
Arrow right icon
Authors (2):
Arrow left icon
Javier Reguera Salgado Javier Reguera Salgado
Author Profile Icon Javier Reguera Salgado
Javier Reguera Salgado
Juan Rufes Juan Rufes
Author Profile Icon Juan Rufes
Juan Rufes
Arrow right icon
View More author details
Toc

Table of Contents (21) Chapters Close

Preface 1. Part 1:Foundations of Parallel Programming and Process Management
2. Chapter 1: Parallel Programming Paradigms FREE CHAPTER 3. Chapter 2: Processes, Threads, and Services 4. Part 2: Advanced Thread Management and Synchronization Techniques
5. Chapter 3: How to Create and Manage Threads in C++ 6. Chapter 4: Thread Synchronization with Locks 7. Chapter 5: Atomic Operations 8. Part 3: Asynchronous Programming with Promises, Futures, and Coroutines
9. Chapter 6: Promises and Futures 10. Chapter 7: The Async Function 11. Chapter 8: Asynchronous Programming Using Coroutines 12. Part 4: Advanced Asynchronous Programming with Boost Libraries
13. Chapter 9: Asynchronous Programming Using Boost.Asio 14. Chapter 10: Coroutines with Boost.Cobalt 15. Part 5: Debugging, Testing, and Performance Optimization in Asynchronous Programming
16. Chapter 11: Logging and Debugging Asynchronous Software 17. Chapter 12: Sanitizing and Testing Asynchronous Software 18. Chapter 13: Improving Asynchronous Software Performance 19. Index 20. Other Books You May Enjoy

The thread library – an introduction

The main library to create and manage threads in C++ is the thread library. First, let’s go through a recap about threads. Then we will dive into what the thread library offers.

What are threads? Let’s do a recap

The purpose of threads is to execute multiple simultaneous tasks in a process.

As we have seen in the previous chapter, a thread has its own stack, local data, and CPU registers such as Instruction Pointer (IP) and Stack Pointer (SP), but shares the address space and virtual memory of its parent process.

In the user space, we can differentiate between native threads and lightweight or virtual threads. Native threads are the ones created by the OS when using some kernel APIs. The C++ thread objects create and manage these types of threads. On the other hand, lightweight threads are like native threads, except that they are emulated by a runtime or library. In C++, coroutines belong to this group. As described in the previous chapter, lightweight threads have faster context switching than native threads. Also, multiple lightweight threads can run in the same native thread and can be much smaller than native threads.

In this chapter, we will start learning about native threads. In Chapter 8, we will learn about lightweight threads in the form of coroutines.

The C++ thread library

In C++, threads allow multiple functions to run concurrently. The thread class defines a type-safe interface to a native thread. This class is defined in the std::thread library, in the <thread> header file in the Standard Template Library (STL). It is available from C++11 onward.

Before the inclusion of the thread library in the C++ STL, developers used platform-specific libraries such as the POSIX thread (pthread) library in Unix or Linux OSs, the C Runtime (CRT) and Win32 libraries for Windows NT and CE systems, or third-party libraries such as Boost.Threads. In this book, we will only use modern C++ features. As <thread> is available and provides a portable abstraction on top of platform-specific mechanisms, none of these libraries will be used or explained. In Chapter 9, we will introduce Boost.Asio, and in Chapter 10, Boost.Cobalt. Both libraries provide advanced frameworks to deal with asynchronous I/O operations and coroutines.

Now it’s time to learn about the different thread operations.

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image