rwlogo
SourcePro C++ 12.0

SourcePro® C++ API Reference Guide



   SourcePro C++
Documentation Home

RWTWriteLockGuard< Resource > Class Template Reference
[Synchronization]

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

#include <rw/sync/RWTWriteLockGuard.h>

Inheritance diagram for RWTWriteLockGuard< Resource >:
RWTWriteLockGuardBase< Resource > RWTWriteGuardBase< Resource >

List of all members.

Public Member Functions

 ~RWTWriteLockGuard ()
 RWTWriteLockGuard (Resource &resource)

Private Member Functions

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

Detailed Description

template<class Resource>
class RWTWriteLockGuard< Resource >

RWTWriteLockGuard<Resource> is a guard class that acquires write access on its resource upon creation and releases it 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 acquire write access on a mutex when created and release it 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/RWTWriteLockGuard.h>
 
 // ...
 RWReadersWriterLock rwlock;
 
 void foo()
 {
    // acquire write access:
    RWTWriteLockGuard<RWReaderWritersLock> lock(rwlock);
   
    // ... critical section
 
    // lock will be released in RWTWriteLockGuard destructor
    // before leaving scope, especially important if an exception
    // might be thrown!
 }
See also:
RWTTryWriteLockGuard<Resource> RWTWriteUnlockGuard<Resource>

Constructor & Destructor Documentation

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

Destructor.

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

Constructs an instance with the given resource and acquires write access on that resource. The resource is released in the destructor of the base class.

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

Copy constructor prohibited.


Member Function Documentation

template<class Resource>
RWTWriteLockGuard<Resource>& RWTWriteLockGuard< Resource >::operator= ( const RWTWriteLockGuard< 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.