 
- C++ Library - Home
- C++ Library - <fstream>
- C++ Library - <iomanip>
- C++ Library - <ios>
- C++ Library - <iosfwd>
- C++ Library - <iostream>
- C++ Library - <istream>
- C++ Library - <ostream>
- C++ Library - <sstream>
- C++ Library - <streambuf>
- C++ Library - <atomic>
- C++ Library - <complex>
- C++ Library - <exception>
- C++ Library - <functional>
- C++ Library - <limits>
- C++ Library - <locale>
- C++ Library - <memory>
- C++ Library - <new>
- C++ Library - <numeric>
- C++ Library - <regex>
- C++ Library - <stdexcept>
- C++ Library - <string>
- C++ Library - <thread>
- C++ Library - <tuple>
- C++ Library - <typeinfo>
- C++ Library - <utility>
- C++ Library - <valarray>
- The C++ STL Library
- C++ Library - <array>
- C++ Library - <bitset>
- C++ Library - <deque>
- C++ Library - <forward_list>
- C++ Library - <list>
- C++ Library - <map>
- C++ Library - <multimap>
- C++ Library - <queue>
- C++ Library - <priority_queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- The C++ Advanced Library
- C++ Library - <any>
- C++ Library - <barrier>
- C++ Library - <bit>
- C++ Library - <chrono>
- C++ Library - <cinttypes>
- C++ Library - <clocale>
- C++ Library - <condition_variable>
- C++ Library - <coroutine>
- C++ Library - <cstdlib>
- C++ Library - <cstring>
- C++ Library - <cuchar>
- C++ Library - <charconv>
- C++ Library - <cfenv>
- C++ Library - <cmath>
- C++ Library - <ccomplex>
- C++ Library - <expected>
- C++ Library - <format>
- C++ Library - <future>
- C++ Library - <flat_set>
- C++ Library - <flat_map>
- C++ Library - <filesystem>
- C++ Library - <generator>
- C++ Library - <initializer_list>
- C++ Library - <latch>
- C++ Library - <memory_resource>
- C++ Library - <mutex>
- C++ Library - <mdspan>
- C++ Library - <optional>
- C++ Library - <print>
- C++ Library - <ratio>
- C++ Library - <scoped_allocator>
- C++ Library - <semaphore>
- C++ Library - <source_location>
- C++ Library - <span>
- C++ Library - <spanstream>
- C++ Library - <stacktrace>
- C++ Library - <stop_token>
- C++ Library - <syncstream>
- C++ Library - <system_error>
- C++ Library - <string_view>
- C++ Library - <stdatomic>
- C++ Library - <variant>
- C++ STL Library Cheat Sheet
- C++ STL - Cheat Sheet
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
C++ Library - <mutex>
The <mutex> header in C++ provides a set of tools designed for managing access to shared resources in multi-threaded environment. The data races may occur, when multiple threads try to access the same resource simultaneously. This library helps to prevent these problems by allowing controlled access to shared resources, ensuring that only one thread can use a particular resource at any given time.
The <mutex> works by locking the resource when a thread needs to access it, Other threads attempting to use the same resource must wait until the mutex is unlocked by the current thread. This library also includes other synchronization primitives like recursive_mutex, timed_mutex and shared_mutex which offers specific functionality suited for different use cases.
Including <mutex> Header
To include the <mutex> header in your C++ program, you can use the following syntax.
#include <mutex>
Functions of <mutex> Header
Below is list of all functions from <mutex> header.
| Sr.No | Functions & Description | 
|---|---|
| 1 | lock It locks specified mutex. | 
| 2 | try_lock It tries to lock the mutex. | 
| 3 | unlock It unlocks the mutex. | 
| 4 | native_handle It return the underlying implementation. | 
Protecting Shared Data
In the following example, we are going to use the mutex to ensure that only one thread can access the shared data at a time.
#include <iostream>
#include <mutex>
#include <thread>
std::mutex a;
int b = 0;
void increment() {
   for (int x = 0; x < 1123; ++x) {
      a.lock();
      ++b;
      a.unlock();
   }
}
int main() {
   std::thread x1(increment);
   std::thread x2(increment);
   x1.join();
   x2.join();
   std::cout << "Result : " << b << std::endl;
   return 0;
}
Output
Output of the above code is as follows −
Result : 2246
Auto Locking & Unlocking
Consider the following example, where we are going to make the mutex to lock and unlock automatically.
#include <iostream>
#include <thread>
#include <mutex>
std::mutex a;
int b = 0;
void increment() {
   std::lock_guard < std::mutex > lock(a);
   ++b;
}
int main() {
   std::thread x1(increment);
   std::thread x2(increment);
   x1.join();
   x2.join();
   std::cout << "Result : " << b << std::endl;
   return 0;
}
Output
Following is the output of the above code −
Result : 2