rwlogo
SourcePro C++ 12.0

SourcePro® C++ API Reference Guide



   SourcePro C++
Documentation Home

RWTWriteUnlockGuard< Resource > Class Template Reference
[Synchronization]

A guard class that releases its resource upon creation and acquires read access to its resource upon destruction. More...

#include <rw/sync/RWTWriteUnlockGuard.h>

Inheritance diagram for RWTWriteUnlockGuard< Resource >:
RWTWriteGuardBase< Resource >

List of all members.

Public Member Functions

 RWTWriteUnlockGuard (Resource &resource)
 ~RWTWriteUnlockGuard ()

Private Member Functions

 RWTWriteUnlockGuard (const RWTWriteUnlockGuard< Resource > &second)
RWTWriteUnlockGuard< Resource > & operator= (const RWTWriteUnlockGuard< Resource > &second)

Detailed Description

template<class Resource>
class RWTWriteUnlockGuard< Resource >

RWTWriteUnlockGuard<Resource> is a guard class that releases its resource upon creation and acquires write access on its resource upon destruction. Guard objects work in conjunction with block statements to establish an appropriate state upon creation, maintain that state for the duration of the block, and restore the original state upon destruction. For example, a guard may release write access on a mutex when created and reacquire write access on that mutex when destructed.

The class used as the actual template parameter for Resource must provide acquireWrite() and release() methods such as the synchronization classes in this module.

Examples

 #include <rw/sync/RWReadersWriterLock.h>
 #include <rw/sync/RWTWriteUnlockGuard.h>
 
 // ...
 RWReadersWriterLock rwlock;
 void foo()
 {
    rwlock.acquireWrite();
 
    // ... critical code
 
    // temporarily release readers-writer lock
    // for duration of block:
    {
       // constructor releases lock:
       RWTWriteUnlockGuard<RWReadersWriterLock> lock(rwlock);
    
       // ... anti-critical section
 
       // lock will be reacquired for writing in
       // RWTWriteUnlockGuard destructor.
    }
    // ... more critical code
    rwlock.release();
 }
See also:
RWTWriteLockGuard<Resource>

Constructor & Destructor Documentation

template<class Resource >
RWTWriteUnlockGuard< Resource >::RWTWriteUnlockGuard ( Resource &  resource  )  [inline]

Releases the resource.

template<class Resource >
RWTWriteUnlockGuard< Resource >::~RWTWriteUnlockGuard (  )  [inline]

Reacquires write access on the resource.

template<class Resource>
RWTWriteUnlockGuard< Resource >::RWTWriteUnlockGuard ( const RWTWriteUnlockGuard< Resource > &  second  )  [private]

Copy construction prohibited.


Member Function Documentation

template<class Resource>
RWTWriteUnlockGuard<Resource>& RWTWriteUnlockGuard< Resource >::operator= ( const RWTWriteUnlockGuard< Resource > &  second  )  [private]

Assignment prohibited.

 All Classes Functions Variables Typedefs Enumerations Enumerator Friends

© Copyright Rogue Wave Software, Inc. All Rights Reserved.
Rogue Wave and SourcePro are registered trademarks of Rogue Wave Software, Inc. in the United States and other countries. All other trademarks are the property of their respective owners.
Contact Rogue Wave about documentation or support issues.