Supports recursive acquisition of a mutex. More...
#include <rw/sync/RWTRecursiveLock.h>
Public Types | |
typedef RWTLockGuard< RWTRecursiveLock< Mutex > > | LockGuard |
typedef RWTReadLockGuard< RWTRecursiveLock< Mutex > > | ReadLockGuard |
typedef RWTReadUnlockGuard< RWTRecursiveLock< Mutex > > | ReadUnlockGuard |
typedef RWTTryLockGuard< RWTRecursiveLock< Mutex > > | TryLockGuard |
typedef RWTTryReadLockGuard< RWTRecursiveLock< Mutex > > | TryReadLockGuard |
typedef RWTTryWriteLockGuard< RWTRecursiveLock< Mutex > > | TryWriteLockGuard |
typedef RWTUnlockGuard< RWTRecursiveLock< Mutex > > | UnlockGuard |
typedef RWTWriteLockGuard< RWTRecursiveLock< Mutex > > | WriteLockGuard |
typedef RWTWriteUnlockGuard< RWTRecursiveLock< Mutex > > | WriteUnlockGuard |
Public Member Functions | |
RWTRecursiveLock (RWCancellationState state=0) | |
~RWTRecursiveLock () | |
void | acquire () |
RWWaitStatus | acquire (unsigned long milliseconds) |
void | acquireRead () |
RWWaitStatus | acquireRead (unsigned long milliseconds) |
void | acquireWrite () |
RWWaitStatus | acquireWrite (unsigned long milliseconds) |
bool | isAcquired () const |
void | release () |
bool | tryAcquire () |
bool | tryAcquireRead () |
bool | tryAcquireWrite () |
Public Member Functions inherited from RWSynchObject | |
void | disableCancellation () |
void | enableCancellation (RWCancellationState) |
bool | isCancellationEnabled () const |
void | setCancellation (RWCancellationState) |
Private Member Functions | |
RWTRecursiveLock (const RWTRecursiveLock< Mutex > &second) | |
RWTRecursiveLock< Mutex > & | operator= (const RWTRecursiveLock< Mutex > &second) |
Additional Inherited Members | |
Protected Member Functions inherited from RWSynchObject | |
RWSynchObject (RWCancellationState state=0) | |
RWSynchObject (RWStaticCtor) | |
RWSynchObject (const RWSynchObject &second) | |
RWSynchObject & | operator= (const RWSynchObject &second) |
void | testCancellation () |
Related Functions inherited from RWSynchObject | |
#define | RW_CANCELLATION_DISABLED |
#define | RW_CANCELLATION_ENABLED |
typedef void(* | RWCancellationState) () |
void | rwServiceCancellation (void) |
The RWMutexLock and RWFIFOMutexLock classes do not allow a thread to acquire the mutex if it already owns it. Attempts to do so result in an assertion and abort in the debug version of the module, and may result in deadlock in the release version.
RWTRecursiveLock can be used to add recursive acquisition semantics to an existing mutex class such as RWMutexLock or RWFIFOMutexLock.
This class allows the thread that owns a mutex to reacquire the mutex any number of times before ever releasing it. For each acquisition, however, the thread must release the mutex the same number of times before the resource can become available to another thread.
typedef RWTLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::LockGuard |
Predefined type for compatible guard.
typedef RWTReadLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::ReadLockGuard |
Predefined type for compatible guard.
typedef RWTReadUnlockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::ReadUnlockGuard |
Predefined type for compatible guard.
typedef RWTTryLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::TryLockGuard |
Predefined type for compatible guard.
typedef RWTTryReadLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::TryReadLockGuard |
Predefined type for compatible guard.
typedef RWTTryWriteLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::TryWriteLockGuard |
Predefined type for compatible guard.
typedef RWTUnlockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::UnlockGuard |
Predefined type for compatible guard.
typedef RWTWriteLockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::WriteLockGuard |
Predefined type for compatible guard.
typedef RWTWriteUnlockGuard< RWTRecursiveLock< Mutex > > RWTRecursiveLock< Mutex >::WriteUnlockGuard |
Predefined type for compatible guard.
RWTRecursiveLock< Mutex >::RWTRecursiveLock | ( | RWCancellationState | state = 0 | ) |
Creates and initializes an RWTRecursiveLock. The thread cancellation state of the object is initialized to state. Possible exceptions include RWTHRResourceLimit and RWTHRInternalError.
|
inline |
Recovers the system resource used to implement the RWTRecursiveLock. Possible exceptions include RWTHRInternalError.
|
private |
Copy construction prohibited.
void RWTRecursiveLock< Mutex >::acquire | ( | ) |
Acquires the recursive lock, incrementing the nesting level for each time the lock owner calls this method.
This function will throw an RWCancellation object if the mutex has cancellation detection enabled and a runnable containing the calling thread has been canceled. Other possible exceptions include RWTHRInternalError.
RWWaitStatus RWTRecursiveLock< Mutex >::acquire | ( | unsigned long | milliseconds | ) |
Acquires the recursive lock, incrementing the nesting level for each time the lock owner calls this method, but timing out if forced to wait for the mutex longer than the specified number of milliseconds. If the call times out, the function returns RW_THR_TIMEOUT.
This function will throw an RWCancellation object if the mutex has cancellation detection enabled and a runnable containing the calling thread has been canceled. Other possible exceptions include RWTHRInternalError.
|
inline |
Calls acquire(). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
|
inline |
Calls acquire(milliseconds). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
|
inline |
Calls acquire(). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
|
inline |
Calls acquire(milliseconds). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
bool RWTRecursiveLock< Mutex >::isAcquired | ( | ) | const |
Determines whether the calling thread currently owns the mutex.
|
private |
Assignment prohibited.
void RWTRecursiveLock< Mutex >::release | ( | ) |
Releases the recursive lock, decrementing the nesting level each time the lock owner calls this method, and releasing the actual lock when the level reaches zero. Possible exceptions include RWTHRIllegalUsage and RWTHRInternalError.
bool RWTRecursiveLock< Mutex >::tryAcquire | ( | ) |
Conditionally acquires the recursive lock, incrementing the nesting level for each time the lock owner calls this method. This method returns immediately if the lock is unavailable. Returns true
if the lock is successfully acquired. Possible exceptions include RWCancellation and RWTHRInternalError.
|
inline |
Calls tryAcquire(). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
|
inline |
Calls tryAcquire(). Provided for compatibility with Read/Write locks. Possible exceptions include RWCancellation and RWTHRInternalError.
Copyright © 2020 Rogue Wave Software, Inc. All Rights Reserved. |