std::atomic_ref<T>::fetch_sub
来自cppreference.com
< cpp | atomic | atomic ref
| 仅为 atomic_ref<Integral> 与 atomic_ref<Floating> 模板特化的成员 |
||
| T fetch_sub( T arg, std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
(1) | (C++20 起) |
| 仅为 atomic_ref<T*> 模板特化的成员 |
||
| T* fetch_sub( std::ptrdiff_t arg, std::memory_order order = std::memory_order_seq_cst ) const noexcept; |
(2) | (C++20 起) |
原子地以当前被引用对象的值和 arg 的算术减法结果替换该值。此操作为读修改写操作。按照 order 的值影响内存。
对于有符号整数类型,定义算术为使用补码进行。无未定义结果。
对于浮点类型,有效的浮点环境可能异于调用方线程的浮点环境。不需要操作服从对应的 std::numeric_limits 特性,但鼓励这么做。若结果不是其类型的可表示值,则结果未指定,但操作不会另有未定义行为。
对于 T* 类型,结果可以为未定义的地址,但操作不会另有未定义行为。若 T 不是对象类型则程序非良构。
参数
| arg | - | 算术减法的另一实参 |
| order | - | 施加的内存定序制约 |
返回值
紧接此函数生效前的被引用对象值。
示例
| 本节未完成 原因:暂无示例 |