|
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Provided only when T is an arithmetic type other thancvbool or a pointer-to-object type | ||
value_type fetch_sub( difference_type arg, std::memory_order order= | (constexpr since C++26) | |
Atomically replaces the current value of the referenced object with the result of arithmetic subtraction of the value andarg. This operation is a read-modify-write operation. Memory is affected according to the value oforder.
This overload participates in overload resolution only ifstd::is_const_v<T> isfalse.
Contents |
| arg | - | the other argument of arithmetic subtraction |
| order | - | memory order constraints to enforce |
The value referenced by*ptr, immediately preceding the effects of this function.
| This section is incomplete Reason: no example |
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 3508 (P3323R1) | C++20 | fetch_sub was meaningless forconst T | constrained to accept only non-constT |