
- The C Standard Library
- The C Standard Library
- The C++ Standard Library
- 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 - <queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
C++ Atomic Library - Fetch Sub
Description
It subtracts a non-atomic value from an atomic object and obtains the previous value of the atomic.
Declaration
Following is the declaration for std::atomic_fetch_sub.
template< class Integral > Integral atomic_fetch_sub( volatile std::atomic<Integral>* obj, Integral arg );
C++11
template< class Integral > Integral atomic_fetch_sub( std::atomic<Integral>* obj, Integral arg );
Following is the declaration for std::atomic_fetch_sub_explicit.
template< class T > T* atomic_fetch_sub_explicit( volatile std::atomic<T*>* obj, std::ptrdiff_t arg, std::memory_order order )
C++11
template< class T > T* atomic_fetch_sub_explicit( std::atomic<T*>* obj, std::ptrdiff_t arg, std::memory_order order );
Parameters
obj − It is used in pointer to the atomic object to modify.
desr − It is used to store the value in the atomic object.
order − It is used to synchronise the memory ordering for this operation.
Return Value
It returns the value immediately preceding the effects of this function in the modification order of *obj.
Exceptions
No-noexcept − this member function never throws exceptions.
Example
In below example for std::atomic_fetch_sub_explicit.
#include <string> #include <thread> #include <vector> #include <iostream> #include <atomic> #include <numeric> const int N = 10000; std::atomic<int> cnt; std::vector<int> data(N); void reader(int id) { for (;;) { int idx = atomic_fetch_sub_explicit(&cnt, 1, std::memory_order_relaxed); if (idx >= 0) { std::cout << "reader " << std::to_string(id) << " processed item " << std::to_string(data[idx]) << '\n'; } else { std::cout << "reader " << std::to_string(id) << " done\n"; break; } } } int main() { std::iota(data.begin(), data.end(), 1); cnt = data.size() - 1; std::vector<std::thread> v; for (int n = 0; n < 10; ++n) { v.emplace_back(reader, n); } for (auto& t : v) { t.join(); } }
The output should be like this −
reader 1 processed item 9997 reader 1 processed item 9992 reader 1 processed item 9991 reader 1 processed item 9990 reader 1 processed item 9989 reader 1 processed item 9988 reader 1 processed item 9987 reader 1 processed item 9986 reader 1 processed item 9985 reader 1 processed item 9984 reader 1 processed item 9983 reader 1 processed item 9982 reader 1 processed item 9981 reader 1 processed item 9980 reader 1 processed item 9979 reader 1 processed item 9978 reader 1 processed item 9977 reader 1 processed item 9976 reader 1 processed item 9975 reader 1 processed item 9974 reader 1 processed item 9973 ............................
atomic.htm
Advertisements