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


Rust Condvar.wait用法及代码示例


本文简要介绍rust语言中 std::sync::Condvar.wait 的用法。

用法

pub fn wait<'a, T>(    &self,     guard: MutexGuard<'a, T>) -> LockResult<MutexGuard<'a, T>>

阻塞当前线程,直到此条件变量收到通知。

此函数将自动解锁指定的互斥锁(由 guard 表示)并阻塞当前线程。这意味着在互斥锁解锁后逻辑上发生的对 notify_one notify_all 的任何调用都是唤醒该线程的候选者。当此函数调用返回时,指定的锁将被重新获取。

请注意,此函数容易受到虚假唤醒的影响。条件变量通常有一个与之关联的布尔谓词,并且每次该函数返回时都必须检查谓词以防止虚假唤醒。

错误

如果当该线程重新获取锁时正在等待的互斥体中毒,则该函数将返回错误。有关详细信息,请参阅有关 Mutex 类型的 poisoning 的信息。

Panics

如果随着时间的推移与多个互斥锁一起使用,此函数可能会 panic!

例子

use std::sync::{Arc, Mutex, Condvar};
use std::thread;

let pair = Arc::new((Mutex::new(false), Condvar::new()));
let pair2 = Arc::clone(&pair);

thread::spawn(move|| {
    let (lock, cvar) = &*pair2;
    let mut started = lock.lock().unwrap();
    *started = true;
    // We notify the condvar that the value has changed.
    cvar.notify_one();
});

// Wait for the thread to start up.
let (lock, cvar) = &*pair;
let mut started = lock.lock().unwrap();
// As long as the value inside the `Mutex<bool>` is `false`, we wait.
while !*started {
    started = cvar.wait(started).unwrap();
}

相关用法


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