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


Rust AtomicI64.compare_exchange_weak用法及代码示例


本文简要介绍rust语言中 core::sync::atomic::AtomicI64.compare_exchange_weak 的用法。

用法

pub fn compare_exchange_weak(    &self,     current: i64,     new: i64,     success: Ordering,     failure: Ordering) -> Result<i64, i64>

如果当前值与 current 值相同,则将值存储到原子整数中。

AtomicI64::compare_exchange 不同,即使比较成功,也允许此函数虚假失败,这可以在某些平台上产生更高效的代码。返回值是指示是否写入新值并包含先前值的结果。

compare_exchange_weak 采用两个 Ordering 参数来说明此操作的内存顺序。 success 说明了与 current 比较成功时发生的读取-修改-写入操作所需的顺序。 failure 说明了比较失败时发生的加载操作所需的顺序。使用 Acquire 作为成功排序使存储成为此操作的一部分 Relaxed ,并使用 Release 使成功加载 Relaxed 。失败排序只能是 SeqCst Acquire Relaxed 并且必须等于或弱于成功排序。

注意:此方法仅适用于支持原子操作的平台i64.

例子

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

let val = AtomicI64::new(4);

let mut old = val.load(Ordering::Relaxed);
loop {
    let new = old * 2;
    match val.compare_exchange_weak(old, new, Ordering::SeqCst, Ordering::Relaxed) {
        Ok(_) => break,
        Err(x) => old = x,
    }
}

相关用法


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