#include <Synch.h>
Inheritance diagram for ACE_Adaptive_Lock


| Public Methods | |
| virtual | ~ACE_Adaptive_Lock (void) | 
| You must also override the destructor function to match with how you construct the underneath <lock_>. | |
| virtual int | remove (void) | 
| virtual int | acquire (void) | 
| Block the thread until the lock is acquired. Returns -1 on failure. | |
| virtual int | tryacquire (void) | 
| virtual int | release (void) | 
| Release the lock. Returns -1 on failure. | |
| virtual int | acquire_read (void) | 
| virtual int | acquire_write (void) | 
| virtual int | tryacquire_read (void) | 
| virtual int | tryacquire_write (void) | 
| virtual int | tryacquire_write_upgrade (void) | 
| void | dump (void) const | 
| Protected Methods | |
| ACE_Adaptive_Lock (void) | |
| Protected Attributes | |
| ACE_Lock* | lock_ | 
This class, as ACE_Lock, provide a set of general locking APIs. However, it defers our decision of what kind of lock to use to the run time and delegates all locking operations to the actual lock. Users must define a constructor in their subclass to initialize <lock_>.
| 
 | 
| You must also override the destructor function to match with how you construct the underneath <lock_>. 
 | 
| 
 | 
| Create and initialize create the actual lcok used in the class. The default constructor simply set the <lock_> to 0 (null). You must overwrite this method for this class to work. | 
| 
 | 
| Block the thread until the lock is acquired. Returns -1 on failure. 
 Reimplemented from ACE_Lock. | 
| 
 | 
| Block until the thread acquires a read lock. If the locking mechanism doesn't support read locks then this just calls . Returns -1 on failure. Reimplemented from ACE_Lock. | 
| 
 | 
| Block until the thread acquires a write lock. If the locking mechanism doesn't support read locks then this just calls . Returns -1 on failure. Reimplemented from ACE_Lock. | 
| 
 | 
| 
 | 
| 
 | 
| Release the lock. Returns -1 on failure. 
 Reimplemented from ACE_Lock. | 
| 
 | 
| Explicitly destroy the lock. Note that only one thread should call this method since it doesn't protect against race conditions. Reimplemented from ACE_Lock. | 
| 
 | 
| Conditionally acquire the lock (i.e., won't block). Returns -1 on failure. If we "failed" because someone else already had the lock, <errno> is set to <EBUSY>. Reimplemented from ACE_Lock. | 
| 
 | 
| Conditionally acquire a read lock. If the locking mechanism doesn't support read locks then this just calls . Returns -1 on failure. If we "failed" because someone else already had the lock, <errno> is set to <EBUSY>. Reimplemented from ACE_Lock. | 
| 
 | 
| Conditionally acquire a write lock. If the locking mechanism doesn't support read locks then this just calls . Returns -1 on failure. If we "failed" because someone else already had the lock, <errno> is set to <EBUSY>. Reimplemented from ACE_Lock. | 
| 
 | 
| Conditionally try to upgrade a lock held for read to a write lock. If the locking mechanism doesn't support read locks then this just calls . Returns 0 on success, -1 on failure. Reimplemented from ACE_Lock. | 
| 
 | 
| 
 | 
 1.2.3 written by Dimitri van Heesch,
 © 1997-2000
1.2.3 written by Dimitri van Heesch,
 © 1997-2000