 
- 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++ Atomic::operator++() function
The C++std::atomic::operator++() function is used for atomic increment operations on atomic objects. This operator ensures that the increment operation is performed atomically, meaning it is thread safe and prevents race conditions.
The operator++() function can be used in both pre-increment and post-increment.
Syntax
Following is the syntax for std::atomic::operator++() function.
T operator++() volatile noexcept; T operator++() noexcept; or T operator++ (int) volatile noexcept; T operator++ (int) noexcept;
Parameters
It does not accept any parameters.
Return Value
It returns the value of the atomic variable after the modification.
Exceptions
This function never throws exceptions.
Example
In the following example, we are going to consider the basic usage of the operator++() function.
#include <iostream>
#include <atomic>
int main()
{
    std::atomic<int> x(1);
    x++;
    std::cout << "Result : " << x << std::endl;
    return 0;
}
Output
Output of the above code is as follows −
Result : 2
Example
Consider the following example, where we are going to use the increment in the loop.
#include <iostream>
#include <atomic>
int main()
{
    std::atomic<int> x(3);
    for (int a = 0; a < 4; ++a) {
        ++x;
    }
    std::cout << "Result : " << x.load() << std::endl;
    return 0;
}
Output
Following is the output of the above code −
Result : 7
Example
Let's look at the following example, where we are going to use pre-increment and post-increment.
#include <iostream>
#include <atomic>
int main()
{
    std::atomic<int> x(2);
    int a = ++x;
    int b = x++;
    std::cout << "Pre-increment: " << a << std::endl;
    std::cout << "Post-increment: " << b << std::endl;
    std::cout << "Result : " << x.load() << std::endl;
    return 0;
}
Output
If we run the above code it will generate the following output −
Pre-increment: 3 Post-increment: 3 Result : 4