[][src]Struct qt_core::QRecursiveMutex

#[repr(C)]pub struct QRecursiveMutex { /* fields omitted */ }

The QRecursiveMutex class is a mutex, like QMutex, with which it is API-compatible. It differs from QMutex by accepting lock() calls from the same thread any number of times. QMutex would deadlock in this situation.

C++ class: QRecursiveMutex.

C++ documentation:

The QRecursiveMutex class is a mutex, like QMutex, with which it is API-compatible. It differs from QMutex by accepting lock() calls from the same thread any number of times. QMutex would deadlock in this situation.

QRecursiveMutex is much more expensive to construct and operate on, so use a plain QMutex whenever you can. Sometimes, one public function, however, calls another public function, and they both need to lock the same mutex. In this case, you have two options:

  • Factor the code that needs mutex protection into private functions, which assume that the mutex is held when they are called, and lock a plain QMutex in the public functions before you call the private implementation ones.
  • Or use a recursive mutex, so it doesn't matter that the first public function has already locked the mutex when the second one wishes to do so.

Methods

impl QRecursiveMutex[src]

pub unsafe fn new() -> CppBox<QRecursiveMutex>[src]

This is supported on cpp_lib_version="5.14.0" only.

Constructs a new recursive mutex. The mutex is created in an unlocked state.

Calls C++ function: [constructor] void QRecursiveMutex::QRecursiveMutex().

C++ documentation:

Constructs a new recursive mutex. The mutex is created in an unlocked state.

See also lock() and unlock().

Trait Implementations

impl CppDeletable for QRecursiveMutex[src]

unsafe fn delete(&self)[src]

Destroys the mutex.

Calls C++ function: [destructor] void QRecursiveMutex::~QRecursiveMutex().

C++ documentation:

Destroys the mutex.

Warning: Destroying a locked mutex may result in undefined behavior.

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T, U> CastInto<U> for T where
    U: CastFrom<T>, 
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> StaticUpcast<T> for T[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.