|  | Home · All Classes · Main Classes · Grouped Classes · Modules · Functions |  | 
The QReadLocker class is a convenience class that simplifies locking and unlocking read-write locks for read access. More...
#include <QReadLocker>
Note: All the functions in this class are thread-safe.
The QReadLocker class is a convenience class that simplifies locking and unlocking read-write locks for read access.
The purpose of QReadLocker (and QWriteLocker) is to simplify QReadWriteLock locking and unlocking. Locking and unlocking statements or in exception handling code is error-prone and difficult to debug. QReadLocker can be used in such situations to ensure that the state of the lock is always well-defined.
Here's an example that uses QReadLocker to lock and unlock a read-write lock for reading:
 QReadWriteLock lock;
 QByteArray readData()
 {
     QReadLocker locker(&lock);
     ...
     return data;
 }
It is equivalent to the following code:
 QReadWriteLock lock;
 QByteArray readData()
 {
     locker.lockForRead();
     ...
     locker.unlock();
     return data;
 }
The QMutexLocker documentation shows examples where the use of a locker object greatly simplifies programming.
See also QWriteLocker and QReadWriteLock.
Constructs a QReadLocker and locks lock for reading. The lock will be unlocked when the QReadLocker is destroyed. If lock is zero, QReadLocker does nothing.
See also QReadWriteLock::lockForRead().
Destroys the QReadLocker and unlocks the lock that was passed to the constructor.
See also QReadWriteLock::unlock().
Returns a pointer to the read-write lock that was passed to the constructor.
Relocks an unlocked lock.
See also unlock().
Unlocks the lock associated with this locker.
See also QReadWriteLock::unlock().
| Copyright © 2007 Trolltech | Trademarks | Qt 4.3.3 |