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 | - | 施加的内存定序制约 |
返回值
紧接此函数生效前的被引用对象值。
示例
本节未完成 原因:暂无示例 |