本文简要介绍rust语言中 core::sync::atomic::AtomicUsize.compare_and_swap 的用法。
用法
pub fn compare_and_swap( &self, current: usize, new: usize, order: Ordering) -> usize如果当前值与 current 值相同,则将值存储到原子整数中。
返回值始终是前一个值。如果它等于 current ,则该值已更新。
compare_and_swap 还接受一个 Ordering 参数,该参数说明了此操作的内存顺序。请注意,即使使用 AcqRel ,操作也可能会失败,因此只执行 Acquire 加载,但没有 Release 语义。使用 Acquire 使存储部分成为此操作 Relaxed (如果发生),使用 Release 使加载部分成为 Relaxed 。
注意:此方法仅适用于支持原子操作的平台usize.
迁移到 compare_exchange 和 compare_exchange_weak
compare_and_swap 等价于 compare_exchange,具有以下内存排序映射:
| 原版的 | 成功 | 失败 |
|---|---|---|
| Relaxed | Relaxed | Relaxed |
| Acquire | Acquire | Acquire |
| Release | Release | Relaxed |
| AcqRel | AcqRel | Acquire |
| SeqCst | SeqCst | SeqCst |
即使比较成功,compare_exchange_weak 也允许虚假失败,这允许编译器在循环中使用比较和交换时生成更好的汇编代码。
例子
use std::sync::atomic::{AtomicUsize, Ordering};
let some_var = AtomicUsize::new(5);
assert_eq!(some_var.compare_and_swap(5, 10, Ordering::Relaxed), 5);
assert_eq!(some_var.load(Ordering::Relaxed), 10);
assert_eq!(some_var.compare_and_swap(6, 12, Ordering::Relaxed), 10);
assert_eq!(some_var.load(Ordering::Relaxed), 10);相关用法
- Rust AtomicUsize.compare_exchange_weak用法及代码示例
- Rust AtomicUsize.compare_exchange用法及代码示例
- Rust AtomicUsize.load用法及代码示例
- Rust AtomicUsize.swap用法及代码示例
- Rust AtomicUsize.fetch_nand用法及代码示例
- Rust AtomicUsize.into_inner用法及代码示例
- Rust AtomicUsize.get_mut用法及代码示例
- Rust AtomicUsize.fetch_add用法及代码示例
- Rust AtomicUsize.fetch_min用法及代码示例
- Rust AtomicUsize.fetch_xor用法及代码示例
- Rust AtomicUsize.fetch_sub用法及代码示例
- Rust AtomicUsize.as_mut_ptr用法及代码示例
- Rust AtomicUsize.fetch_and用法及代码示例
- Rust AtomicUsize.from_mut用法及代码示例
- Rust AtomicUsize.store用法及代码示例
- Rust AtomicUsize.fetch_max用法及代码示例
- Rust AtomicUsize.new用法及代码示例
- Rust AtomicUsize.fetch_or用法及代码示例
- Rust AtomicUsize.fetch_update用法及代码示例
- Rust AtomicU8.fetch_sub用法及代码示例
- Rust AtomicU32.fetch_min用法及代码示例
- Rust AtomicU8.fetch_or用法及代码示例
- Rust AtomicU16.into_inner用法及代码示例
- Rust AtomicU16.from_mut用法及代码示例
- Rust AtomicU8.as_mut_ptr用法及代码示例
注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 core::sync::atomic::AtomicUsize.compare_and_swap。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。
