std::atomic_ref<T>::operator+=,-=
来自 cppreference.com
< cpp | atomic | atomic ref
仅 atomic_ref<Integral> 和 atomic_ref<Floating> 专门化的成员 |
||
T operator+=( T arg ) const noexcept; |
(1) | (自 C++20 起) |
T operator-=( T arg ) const noexcept; |
(2) | (自 C++20 起) |
仅 atomic_ref<T*> 部分专门化的成员 |
||
T* operator+=( std::ptrdiff_t arg ) const noexcept; |
(3) | (自 C++20 起) |
T* operator-=( std::ptrdiff_t arg ) const noexcept; |
(4) | (自 C++20 起) |
原子地将引用对象的当前值替换为涉及先前值和 arg 的计算结果。这些操作是读-修改-写操作。
- operator+= 执行原子加法。等效于 return fetch_add(arg) + arg;.
- operator-= 执行原子减法。等效于 return fetch_sub(arg) - arg;.
1,2) 对于有符号整数类型,算术运算定义为使用二进制补码表示。没有未定义的结果。
对于浮点类型,生效的 浮点环境 可能与调用线程的浮点环境不同。该操作不必符合相应的 std::numeric_limits 特性,但鼓励这样做。如果结果不是其类型的可表示值,则结果是不确定的,但操作本身没有未定义的行为。
3,4) 结果可能是未定义的地址,但操作本身没有未定义的行为。如果
T
不是对象类型,则程序格式错误。内容 |
[编辑] 参数
arg | - | 算术运算的参数 |
[编辑] 返回值
结果值(即,将相应二元运算符应用于紧接相应成员函数效果之前的值的結果)。
[编辑] 说明
与大多数复合赋值运算符不同,atomic_ref
的复合赋值运算符不返回对其左操作数的引用。相反,它们返回存储值的副本。
[编辑] 示例
本节不完整 原因:没有示例 |
[编辑] 另请参阅
原子地将参数加到存储在引用对象中的值并获取先前保存的值 (公共成员函数) | |
原子地将参数从存储在引用对象中的值减去并获取先前保存的值 (公共成员函数) | |
原子地将引用对象加一或减一 (公共成员函数) | |
原子地对引用值执行按位 AND、OR、XOR 运算 (公有成员函数) |