sigx++
2.0.1
|
Locks the given mutex and ensures threadsafe write access to the given locked type. More...
#include <lock_acquirer.h>
Public Member Functions | |
lock_acquirer (volatile_reference_type _a_value, mutex_type &_a_mutex) | |
Constructs a lock_acquirer from a volatile type to protect and a lock. | |
template<typename T_lockfwd_arg1 > | |
lock_acquirer (volatile_reference_type _a_value, mutex_type &_a_mutex, T_lockfwd_arg1 lockfwd_arg1) | |
Constructs a lock_acquirer from a volatile type to protect, a lock and an additional argument forwarded to the lock constructor. |
Protected Types | |
typedef T_type | acquired_type |
typedef T_mutex | mutex_type |
typedef std::tr1::remove_reference < acquired_type >::type | value_type |
typedef boost::mpl::eval_if_c < I_policy==readlock, std::tr1::add_const < value_type > , boost::mpl::identity < value_type > >::type | const_or_value_type |
typedef std::tr1::add_reference < typename std::tr1::add_volatile < value_type >::type >::type | volatile_reference_type |
typedef std::tr1::add_reference < typename std::tr1::remove_volatile < const_or_value_type >::type > ::type | reference_type |
Protected Member Functions | |
reference_type | access_acquiree () throw () |
Protected Attributes | |
choose_lock< mutex_type, I_policy >::type | m_lock |
lock manager appropriate for the lock type | |
reference_type | m_acquiree |
non-const reference to the locked object |
Friends | |
reference_type | access_acquiree (lock_acquirer &l) throw () |
Gives non-volatile access to the locked type. |
Additional Inherited Members |
Locks the given mutex and ensures threadsafe write access to the given locked type.
Collects acquisition of a mutex lock and a volatile_cast from a volatile object. A lock_acquirer object is initialized with a lock from an associated mutex and a volatile object. The appropriate lock is chosen by the metafunction choose_lock according to the mutex and the locking policy (read/write). Note that because the lock_acquirer is scope bound choose_lock must only choose scoped lock types.
During its lifetime, a lock_acquirer keeps the lock acquired. Also, lock_acquirer offers read or write access (according to the locking policy) to the volatile-stripped object. Access is granted by a protected friend template function access_acquiree(). The volatile_cast is performed by access_acquiree(). The cast is semantically valid because lock_acquirer keeps the lock acquired for its lifetime.
If the locking policy is readlock then the lock_acquirer grants only const access to the protected variable.
The following template arguments are used:
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
protected |
|
inline |
Constructs a lock_acquirer from a volatile type to protect and a lock.
|
inline |
Constructs a lock_acquirer from a volatile type to protect, a lock and an additional argument forwarded to the lock constructor.
|
inlineprotected |
|
friend |
Gives non-volatile access to the locked type.
Forces the programmer to pass a previously named lock_acquirer object thus ensuring that the lock is active throughout the usage of the locked object.
|
protected |
non-const reference to the locked object
|
protected |
lock manager appropriate for the lock type