本文簡要介紹rust語言中 std::sync::Condvar.wait_while
的用法。
用法
pub fn wait_while<'a, T, F>( &self, guard: MutexGuard<'a, T>, condition: F) -> LockResult<MutexGuard<'a, T>> where F: FnMut(&mut T) -> bool,
阻塞當前線程,直到此條件變量收到通知並且提供的條件為 false。
此函數將自動解鎖指定的互斥鎖(由 guard
表示)並阻塞當前線程。這意味著在互斥鎖解鎖後邏輯上發生的對 notify_one
或 notify_all
的任何調用都是喚醒該線程的候選者。當此函數調用返回時,指定的鎖將被重新獲取。
錯誤
如果當該線程重新獲取鎖時正在等待的互斥體中毒,則該函數將返回錯誤。有關詳細信息,請參閱有關 Mutex
類型的 poisoning 的信息。
例子
use std::sync::{Arc, Mutex, Condvar};
use std::thread;
let pair = Arc::new((Mutex::new(true), Condvar::new()));
let pair2 = Arc::clone(&pair);
thread::spawn(move|| {
let (lock, cvar) = &*pair2;
let mut pending = lock.lock().unwrap();
*pending = false;
// We notify the condvar that the value has changed.
cvar.notify_one();
});
// Wait for the thread to start up.
let (lock, cvar) = &*pair;
// As long as the value inside the `Mutex<bool>` is `true`, we wait.
let _guard = cvar.wait_while(lock.lock().unwrap(), |pending| { *pending }).unwrap();
相關用法
- Rust Condvar.wait_timeout用法及代碼示例
- Rust Condvar.wait_timeout_while用法及代碼示例
- Rust Condvar.wait_timeout_ms用法及代碼示例
- Rust Condvar.wait用法及代碼示例
- Rust Condvar.notify_all用法及代碼示例
- Rust Condvar.new用法及代碼示例
- Rust Condvar.notify_one用法及代碼示例
- Rust Condvar用法及代碼示例
- Rust ControlFlow用法及代碼示例
- Rust ControlFlow.break_value用法及代碼示例
- Rust ControlFlow.is_break用法及代碼示例
- Rust Concat用法及代碼示例
- Rust ControlFlow.is_continue用法及代碼示例
- Rust Command.args用法及代碼示例
- Rust Cow.is_owned用法及代碼示例
- Rust Cow用法及代碼示例
- Rust Command.env用法及代碼示例
- Rust Command.env_remove用法及代碼示例
- Rust Command.get_args用法及代碼示例
- Rust Command.stdout用法及代碼示例
- Rust Command.stdin用法及代碼示例
- Rust Components用法及代碼示例
- Rust Component.as_os_str用法及代碼示例
- Rust Command.current_dir用法及代碼示例
- Rust Command.output用法及代碼示例
注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 std::sync::Condvar.wait_while。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。