#include <Atomic_Op_T.h>

| Public Types | |
| typedef ACE_Type_Traits< TYPE > ::parameter_type | arg_type | 
| Public Member Functions | |
| ACE_Atomic_Op_Ex (ACE_LOCK &mtx) | |
| Initialize value_to 0. | |
| ACE_Atomic_Op_Ex (ACE_LOCK &mtx, arg_type c) | |
| Initialize value_to c. | |
| TYPE | operator++ (void) | 
| Atomically pre-increment value_. | |
| TYPE | operator++ (int) | 
| Atomically post-increment value_. | |
| TYPE | operator+= (arg_type rhs) | 
| Atomically increment value_by rhs. | |
| TYPE | operator-- (void) | 
| Atomically pre-decrement value_. | |
| TYPE | operator-- (int) | 
| Atomically post-decrement value_. | |
| TYPE | operator-= (arg_type rhs) | 
| Atomically decrement value_by rhs. | |
| bool | operator== (arg_type rhs) const | 
| Atomically compare value_with rhs. | |
| bool | operator!= (arg_type rhs) const | 
| Atomically compare value_with rhs. | |
| bool | operator>= (arg_type rhs) const | 
| Atomically check if value_greater than or equal to rhs. | |
| bool | operator> (arg_type rhs) const | 
| Atomically check if value_greater than rhs. | |
| bool | operator<= (arg_type rhs) const | 
| Atomically check if value_less than or equal to rhs. | |
| bool | operator< (arg_type rhs) const | 
| Atomically check if value_less than rhs. | |
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > & | operator= (arg_type rhs) | 
| Atomically assign rhs to value_. | |
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > & | operator= (ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > const &rhs) | 
| Atomically assign <rhs> to value_. | |
| TYPE | value (void) const | 
| Explicitly return value_. | |
| void | dump (void) const | 
| Dump the state of an object. | |
| ACE_Atomic_Op_Ex (ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > const &) | |
| Manage copying... | |
| ACE_LOCK & | mutex (void) | 
| TYPE & | value_i (void) | 
| Private Attributes | |
| ACE_LOCK & | mutex_ | 
| Type of synchronization mechanism. | |
| TYPE | value_ | 
| Current object decorated by the atomic op. | |
This class is described in an article in the July/August 1994 issue of the C++ Report magazine. It implements a templatized version of the Decorator pattern from the GoF book.
ACE_Atomic_Op_Ex objects must be constructed with a reference to an existing lock. A single lock can be shared between multiple ACE_Atomic_Op_Ex objects. If you do not require this ability consider using the ACE_Atomic_Op class instead, which may be able to take advantage of platform-specific optimisations to provide atomic operations without requiring a lock.
| typedef ACE_Type_Traits<TYPE>::parameter_type ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::arg_type | 
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::ACE_Atomic_Op_Ex | ( | ACE_LOCK & | mtx | ) |  [inline] | 
Initialize value_ to 0. 
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::ACE_Atomic_Op_Ex | ( | ACE_LOCK & | mtx, | |
| arg_type | c | |||
| ) | 
Initialize value_ to c. 
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::ACE_Atomic_Op_Ex | ( | ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > const & | rhs | ) |  [inline] | 
Manage copying...
| void ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::dump | ( | void | ) | const  [inline] | 
Dump the state of an object.
| ACE_LOCK & ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::mutex | ( | void | ) |  [inline] | 
Returns a reference to the underlying <ACE_LOCK>. This makes it possible to acquire the lock explicitly, which can be useful in some cases if you instantiate the <ACE_Atomic_Op_Ex> with an ACE_Recursive_Mutex or ACE_Process_Mutex.
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator!= | ( | arg_type | rhs | ) | const | 
Atomically compare value_ with rhs. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator++ | ( | int | ) |  [inline] | 
Atomically post-increment value_. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator++ | ( | void | ) |  [inline] | 
Atomically pre-increment value_. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator+= | ( | arg_type | rhs | ) | 
Atomically increment value_ by rhs. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator-- | ( | int | ) |  [inline] | 
Atomically post-decrement value_. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator-- | ( | void | ) |  [inline] | 
Atomically pre-decrement value_. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator-= | ( | arg_type | rhs | ) | 
Atomically decrement value_ by rhs. 
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator< | ( | arg_type | rhs | ) | const | 
Atomically check if value_ less than rhs. 
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator<= | ( | arg_type | rhs | ) | const | 
Atomically check if value_ less than or equal to rhs. 
| ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > & ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator= | ( | ACE_Atomic_Op_Ex< ACE_LOCK, TYPE > const & | rhs | ) |  [inline] | 
Atomically assign <rhs> to value_. 
| ACE_Atomic_Op_Ex<ACE_LOCK, TYPE>& ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator= | ( | arg_type | rhs | ) | 
Atomically assign rhs to value_. 
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator== | ( | arg_type | rhs | ) | const | 
Atomically compare value_ with rhs. 
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator> | ( | arg_type | rhs | ) | const | 
Atomically check if value_ greater than rhs. 
| bool ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::operator>= | ( | arg_type | rhs | ) | const | 
Atomically check if value_ greater than or equal to rhs. 
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::value | ( | void | ) | const  [inline] | 
Explicitly return value_. 
| TYPE & ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::value_i | ( | void | ) |  [inline] | 
Explicitly return value_ (by reference). This gives the user full, unrestricted access to the underlying value. This method will usually be used in conjunction with explicit access to the lock. Use with care ;-) 
| ACE_LOCK& ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::mutex_  [private] | 
Type of synchronization mechanism.
| TYPE ACE_Atomic_Op_Ex< ACE_LOCK, TYPE >::value_  [private] | 
Current object decorated by the atomic op.
 1.5.8
 1.5.8