xwrust::xwos::lock::mtx

Struct MutexGuard

source
pub struct MutexGuard<'a, T: ?Sized + 'a> { /* private fields */ }
Expand description

互斥锁对象的RAII Guard

RAII Guard 用于提供 Scoped Lock 机制。

  • MutexGuard 中包含 Mutex 的引用, 当 MutexGuard 生命周期结束时,会在 drop() 方法中自动解锁互斥锁。
  • MutexGuard 不可在线程之间转移所有权,因为其 drop() 方法包含解锁的语义,上锁和解锁必须在同一线程;
  • MutexGuard 虽然可以在多线程中传递引用( Sync 约束),但其实现中没有 unlock() 方法,意味着其他线程即便拿到引用也不能解锁。

Implementations§

source§

impl<'a, T: ?Sized> MutexGuard<'a, T>

source

pub fn wait(self, cond: &Cond) -> Result<MutexGuard<'a, T>, CondError>

阻塞当前线程,直到被条件量唤醒

此方法会消费互斥锁的守卫(Guard),并当线程阻塞时,在条件量内部释放互斥锁。 当条件成立,线程被唤醒,会在条件量内部上锁互斥锁,并重新返回互斥锁的守卫(Guard)。

  • 当返回互斥锁的守卫 MutexGuard 时,互斥锁已经被重新上锁;
  • 当返回 Err() 时,互斥锁未被上锁。
§参数说明
  • cond: 条件量的引用
§上下文
  • 线程
§错误码
§示例
use xwrust::xwos::thd;
use xwrust::xwos::lock::mtx::*;
use xwrust::xwos::sync::cond::*;
extern crate alloc;
use alloc::sync::Arc;

pub fn xwrust_example_mutex() {
    let pair = Arc::new((Mutex::new(true), Cond::new()));
    pair.0.init();
    pair.1.init();
    let pair_c = pair.clone();

    thd::Builder::new()
        .name("child".into())
        .spawn(move |_| { // 子线程闭包
            cthd::sleep(xwtm::ms(500));
            let (lock, cvar) = &*pair_c;
            match lock_child.lock() {
                Ok(mut guard) => {
                    *guard = false; // 设置共享数据
                    drop(guard); // 先解锁再触发条件可提高效率
                    cvar.broadcast();
                },
                Err(e) => { // 子线程上锁失败
                },
            }
        });
    let (lock, cvar) = &*pair;
    let mut guard;
    match lock.lock() {
        Ok(g) => {
            guard = g;
            while *guard {
                match guard.wait(cvar) {
                    Ok(g) => { // 唤醒
                        guard = g;
                    },
                    Err(e) => { // 等待条件量失败
                        break;
                    },
                }
            }
        },
        Err(e) => { // 上锁失败
        },
    }
}
source

pub fn wait_to( self, cond: &Cond, to: XwTm, ) -> Result<MutexGuard<'a, T>, CondError>

限时阻塞当前线程,直到被条件量唤醒

此方法会消费互斥锁的守卫(Guard),并当线程阻塞时,在条件量内部释放互斥锁。 当条件成立,线程被唤醒,会在条件量内部上锁互斥锁,并重新返回互斥锁的守卫(Guard)。 当超时后,将返回错误。

  • 当返回互斥锁的守卫 MutexGuard 时,互斥锁已经被重新上锁;
  • 当返回 Err() 时,互斥锁未被上锁。
§参数说明
  • cond: 条件量的引用
  • to: 期望唤醒的时间点
§上下文
  • 线程
§错误码
§示例
use xwrust::xwos::thd;
use xwrust::xwos::lock::mtx::*;
use xwrust::xwos::sync::cond::*;
extern crate alloc;
use alloc::sync::Arc;

pub fn xwrust_example_mutex() {
    let pair = Arc::new((Mutex::new(true), Cond::new()));
    pair.0.init();
    pair.1.init();
    let pair_c = pair.clone();

    thd::Builder::new()
        .name("child".into())
        .spawn(move |_| { // 子线程闭包
            cthd::sleep(xwtm::ms(500));
            let (lock, cvar) = &*pair_c;
            match lock_child.lock() {
                Ok(mut guard) => {
                    *guard = false; // 设置共享数据
                    drop(guard); // 先解锁再触发条件可提高效率
                    cvar.broadcast();
                },
                Err(e) => { // 子线程上锁失败
                },
            }
        });
    let (lock, cvar) = &*pair;
    let mut guard;
    match lock.lock() {
        Ok(g) => {
            guard = g;
            while *guard {
                match guard.wait_to(cvar, xwtm::ft(xwtm::s(2))) {
                    Ok(g) => { // 唤醒
                        guard = g;
                    },
                    Err(e) => { // 等待条件量失败
                        break;
                    },
                }
            }
        },
        Err(e) => { // 上锁失败
        },
    }
}
source

pub fn wait_unintr(self, cond: &Cond) -> Result<MutexGuard<'a, T>, CondError>

阻塞当前线程,直到被条件量唤醒,且阻塞不可被中断

此方法会消费互斥锁的守卫(Guard),并当线程阻塞时,在条件量内部释放互斥锁。 当条件成立,线程被唤醒,会在条件量内部上锁互斥锁,并重新返回互斥锁的守卫(Guard)。

  • 当返回互斥锁的守卫 MutexGuard 时,互斥锁已经被重新上锁;
  • 当返回 Err() 时,互斥锁未被上锁。
§参数说明
  • cond: 条件量的引用
§上下文
  • 线程
§错误码
§示例
use xwrust::xwos::thd;
use xwrust::xwos::lock::mtx::*;
use xwrust::xwos::sync::cond::*;
extern crate alloc;
use alloc::sync::Arc;

pub fn xwrust_example_mutex() {
    let pair = Arc::new((Mutex::new(true), Cond::new()));
    pair.0.init();
    pair.1.init();
    let pair_c = pair.clone();

    thd::Builder::new()
        .name("child".into())
        .spawn(move |_| { // 子线程闭包
            cthd::sleep(xwtm::ms(500));
            let (lock, cvar) = &*pair_c;
            match lock_child.lock() {
                Ok(mut guard) => {
                    *guard = false; // 设置共享数据
                    drop(guard); // 先解锁再触发条件可提高效率
                    cvar.broadcast();
                },
                Err(e) => { // 子线程上锁失败
                },
            }
        });
    let (lock, cvar) = &*pair;
    let mut guard;
    match lock.lock() {
        Ok(g) => {
            guard = g;
            while *guard {
                match guard.wait_unintr(cvar) {
                    Ok(g) => { // 唤醒
                        guard = g;
                    },
                    Err(e) => { // 等待条件量失败
                        break;
                    },
                }
            }
        },
        Err(e) => { // 上锁失败
        },
    }
}

Trait Implementations§

source§

impl<T: ?Sized> Deref for MutexGuard<'_, T>

source§

type Target = T

The resulting type after dereferencing.
source§

fn deref(&self) -> &T

Dereferences the value.
source§

impl<T: ?Sized> DerefMut for MutexGuard<'_, T>

source§

fn deref_mut(&mut self) -> &mut T

Mutably dereferences the value.
source§

impl<T: ?Sized> Drop for MutexGuard<'_, T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<T: ?Sized> !Send for MutexGuard<'_, T>

source§

impl<T: ?Sized + Sync> Sync for MutexGuard<'_, T>

Auto Trait Implementations§

§

impl<'a, T> Freeze for MutexGuard<'a, T>
where T: ?Sized,

§

impl<'a, T> !RefUnwindSafe for MutexGuard<'a, T>

§

impl<'a, T> Unpin for MutexGuard<'a, T>
where T: ?Sized,

§

impl<'a, T> !UnwindSafe for MutexGuard<'a, T>

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, U> Into<U> for T
where U: From<T>,

§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of [From]<T> for U chooses to do.

§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.