当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Rust AtomicPtr.compare_and_swap用法及代码示例


本文简要介绍rust语言中 std::sync::atomic::AtomicPtr.compare_and_swap 的用法。

用法

pub fn compare_and_swap(    &self,     current: *mut T,     new: *mut T,     order: Ordering) -> *mut T

如果当前值与current 值相同,则将值存储到指针中。

返回值始终是前一个值。如果它等于 current ,则该值已更新。

compare_and_swap 还接受一个 Ordering 参数,该参数说明了此操作的内存顺序。请注意,即使使用 AcqRel ,操作也可能会失败,因此只执行 Acquire 加载,但没有 Release 语义。使用 Acquire 使存储部分成为此操作 Relaxed (如果发生),使用 Release 使加载部分成为 Relaxed

注意:此方法仅在支持指针原子操作的平台上可用。

迁移到 compare_exchangecompare_exchange_weak

compare_and_swap 等价于 compare_exchange,具有以下内存排序映射:

原版的成功失败
RelaxedRelaxedRelaxed
AcquireAcquireAcquire
ReleaseReleaseRelaxed
AcqRelAcqRelAcquire
SeqCstSeqCstSeqCst

即使比较成功,compare_exchange_weak 也允许虚假失败,这允许编译器在循环中使用比较和交换时生成更好的汇编代码。

例子

use std::sync::atomic::{AtomicPtr, Ordering};

let ptr = &mut 5;
let some_ptr  = AtomicPtr::new(ptr);

let other_ptr   = &mut 10;

let value = some_ptr.compare_and_swap(ptr, other_ptr, Ordering::Relaxed);

相关用法


注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 std::sync::atomic::AtomicPtr.compare_and_swap。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。