Struct std::sync::PoisonError

1.0.0 · source ·
pub struct PoisonError<T> { /* private fields */ }
Expand description

一种错误类型,每当获取锁时都可以返回该错误。

每当持有锁的线程发生故障时,MutexRwLock 都会中毒。 锁中毒的确切语义记录在每个锁上,但是一旦锁中毒,则所有 future 获取都将返回此错误。

Examples

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

let mutex = Arc::new(Mutex::new(1));

// 互斥锁中毒
let c_mutex = Arc::clone(&mutex);
let _ = thread::spawn(move || {
    let mut data = c_mutex.lock().unwrap();
    *data = 2;
    panic!();
}).join();

match mutex.lock() {
    Ok(_) => unreachable!(),
    Err(p_err) => {
        let data = p_err.get_ref();
        println!("recovered: {data}");
    }
};
Run

Implementations§

source§

impl<T> PoisonError<T>

1.2.0 · source

pub fn new(guard: T) -> PoisonError<T>

创建一个 PoisonError

这通常是由 Mutex::lockRwLock::read 之类的方法创建的。

1.2.0 · source

pub fn into_inner(self) -> T

消耗这个错误指示锁已中毒,无论如何都将返回底层防护以允许访问。

Examples
use std::collections::HashSet;
use std::sync::{Arc, Mutex};
use std::thread;

let mutex = Arc::new(Mutex::new(HashSet::new()));

// 互斥锁中毒
let c_mutex = Arc::clone(&mutex);
let _ = thread::spawn(move || {
    let mut data = c_mutex.lock().unwrap();
    data.insert(10);
    panic!();
}).join();

let p_err = mutex.lock().unwrap_err();
let data = p_err.into_inner();
println!("recovered {} items", data.len());
Run
1.2.0 · source

pub fn get_ref(&self) -> &T

到达此错误时就表示锁已中毒,返回对底层保护的引用以允许访问。

1.2.0 · source

pub fn get_mut(&mut self) -> &mut T

到达此错误时就表示锁已中毒,返回对底层保护的可变引用以允许访问。

Trait Implementations§

source§

impl<T> Debug for PoisonError<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

使用给定的格式化程序格式化该值。 Read more
source§

impl<T> Display for PoisonError<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

使用给定的格式化程序格式化该值。 Read more
source§

impl<T> Error for PoisonError<T>

source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.30.0 · source§

fn source(&self) -> Option<&(dyn Error + 'static)>

此错误的下级来源 (如果有)。 Read more
source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn provide<'a>(&'a self, demand: &mut Demand<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access #99301)
提供对用于错误报告的上下文的基于类型的访问。 Read more
source§

impl<T> From<PoisonError<T>> for TryLockError<T>

source§

fn from(err: PoisonError<T>) -> TryLockError<T>

从输入类型转换为此类型。

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for PoisonError<T>where T: RefUnwindSafe,

§

impl<T> Send for PoisonError<T>where T: Send,

§

impl<T> Sync for PoisonError<T>where T: Sync,

§

impl<T> Unpin for PoisonError<T>where T: Unpin,

§

impl<T> UnwindSafe for PoisonError<T>where T: UnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

获取 selfTypeIdRead more
source§

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

source§

fn borrow(&self) -> &T

从拥有的值中一成不变地借用。 Read more
source§

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

source§

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

从拥有的值中借用。 Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

返回未更改的参数。

source§

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

source§

fn into(self) -> U

调用 U::from(self)

也就是说,这种转换是 From<T> for U 实现选择执行的任何操作。

source§

impl<E> Provider for Ewhere E: Error + ?Sized,

source§

fn provide<'a>(&'a self, demand: &mut Demand<'a>)

🔬This is a nightly-only experimental API. (provide_any #96024)
数据提供者应实现此方法以提供他们能够通过使用 demand 提供的所有值。 Read more
source§

impl<T> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

将给定值转换为 StringRead more
source§

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

§

type Error = Infallible

发生转换错误时返回的类型。
source§

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

执行转换。
source§

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

§

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

发生转换错误时返回的类型。
source§

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

执行转换。