This class implements a standard reMutex by making direct calls to the underlying implementation layer. More...
#include "reMutexDirect.h"
Public Member Functions | |
void | acquire () const |
Grabs the reMutex if it is available. More... | |
void | acquire (Thread *current_thread) const |
This variant on acquire() accepts the current thread as a parameter, if it is already known, as an optimization. More... | |
void | clear_name () |
The mutex name is only defined when compiling in DEBUG_THREADS mode. More... | |
bool | debug_is_locked () const |
Returns true if the current thread has locked the ReMutex, false otherwise. More... | |
void | elevate_lock () const |
This method increments the lock count, assuming the calling thread already holds the lock. More... | |
std::string | get_name () const |
The mutex name is only defined when compiling in DEBUG_THREADS mode. More... | |
bool | has_name () const |
The mutex name is only defined when compiling in DEBUG_THREADS mode. More... | |
void | lock () |
Alias for acquire() to match C++11 semantics. More... | |
void | output (std::ostream &out) const |
This method is declared virtual in MutexDebug, but non-virtual in ReMutexDirect. More... | |
void | release () const |
Releases the reMutex. More... | |
void | set_name (const std::string &name) |
The mutex name is only defined when compiling in DEBUG_THREADS mode. More... | |
bool | try_acquire () const |
Returns immediately, with a true value indicating the mutex has been acquired, and false indicating it has not. More... | |
bool | try_acquire (Thread *current_thread) const |
Returns immediately, with a true value indicating the mutex has been acquired, and false indicating it has not. More... | |
bool | try_lock () |
Alias for try_acquire() to match C++11 semantics. More... | |
void | unlock () |
Alias for release() to match C++11 semantics. More... | |
Friends | |
class | LightReMutexDirect |
This class implements a standard reMutex by making direct calls to the underlying implementation layer.
It doesn't perform any debugging operations.
Definition at line 29 of file reMutexDirect.h.
|
inline |
Grabs the reMutex if it is available.
If it is not available, blocks until it becomes available, then grabs it. In either case, the function does not return until the reMutex is held; you should then call unlock().
This method is considered const so that you can lock and unlock const reMutexes, mainly to allow thread-safe access to otherwise const data.
Also see ReMutexHolder.
Definition at line 82 of file reMutexDirect.I.
Referenced by ReMutexHolder::ReMutexHolder().
|
inline |
This variant on acquire() accepts the current thread as a parameter, if it is already known, as an optimization.
Definition at line 96 of file reMutexDirect.I.
|
inline |
The mutex name is only defined when compiling in DEBUG_THREADS mode.
Definition at line 192 of file reMutexDirect.I.
|
inline |
Returns true if the current thread has locked the ReMutex, false otherwise.
This method is only intended for use in debugging, hence the method name; in the ReMutexDirect case, it always returns true, since there's not a reliable way to determine this otherwise.
Definition at line 177 of file reMutexDirect.I.
|
inline |
This method increments the lock count, assuming the calling thread already holds the lock.
After this call, release() will need to be called one additional time to release the lock.
This method really performs the same function as acquire(), but it offers a potential (slight) performance benefit when the calling thread knows that it already holds the lock. It is an error to call this when the calling thread does not hold the lock.
Definition at line 144 of file reMutexDirect.I.
|
inline |
The mutex name is only defined when compiling in DEBUG_THREADS mode.
Definition at line 207 of file reMutexDirect.I.
|
inline |
The mutex name is only defined when compiling in DEBUG_THREADS mode.
Definition at line 199 of file reMutexDirect.I.
|
inline |
Alias for acquire() to match C++11 semantics.
Definition at line 34 of file reMutexDirect.I.
Referenced by PT().
void ReMutexDirect::output | ( | std::ostream & | out | ) | const |
This method is declared virtual in MutexDebug, but non-virtual in ReMutexDirect.
Definition at line 24 of file reMutexDirect.cxx.
|
inline |
Releases the reMutex.
It is an error to call this if the reMutex was not already locked.
This method is considered const so that you can lock and unlock const reMutexes, mainly to allow thread-safe access to otherwise const data.
Definition at line 161 of file reMutexDirect.I.
|
inline |
The mutex name is only defined when compiling in DEBUG_THREADS mode.
Definition at line 185 of file reMutexDirect.I.
|
inline |
Returns immediately, with a true value indicating the mutex has been acquired, and false indicating it has not.
Definition at line 110 of file reMutexDirect.I.
|
inline |
Returns immediately, with a true value indicating the mutex has been acquired, and false indicating it has not.
Definition at line 124 of file reMutexDirect.I.
|
inline |
Alias for try_acquire() to match C++11 semantics.
Definition at line 48 of file reMutexDirect.I.
Referenced by BamCache::consider_flush_index().
|
inline |
Alias for release() to match C++11 semantics.
Definition at line 62 of file reMutexDirect.I.
Referenced by BamCache::consider_flush_index(), and PT().