
We bake cookies in your browser for a better experience. Using this site means that you consent.Read More
TheQReadLocker class is a convenience class that simplifies locking and unlocking read-write locks for read access.More...
| Header: | #include <QReadLocker> |
Note: All functions in this class arethread-safe.
| QReadLocker(QReadWriteLock * lock) | |
| ~QReadLocker() | |
| QReadWriteLock * | readWriteLock() const |
| void | relock() |
| void | unlock() |
TheQReadLocker class is a convenience class that simplifies locking and unlocking read-write locks for read access.
The purpose ofQReadLocker (andQWriteLocker) is to simplifyQReadWriteLock 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 usesQReadLocker 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(){ lock.lockForRead();... lock.unlock();return data;}
TheQMutexLocker documentation shows examples where the use of a locker object greatly simplifies programming.
See alsoQWriteLocker andQReadWriteLock.
Constructs aQReadLocker and lockslock for reading. The lock will be unlocked when theQReadLocker is destroyed. Iflock is zero,QReadLocker does nothing.
See alsoQReadWriteLock::lockForRead().
Destroys theQReadLocker and unlocks the lock that was passed to the constructor.
See alsoQReadWriteLock::unlock().
Returns a pointer to the read-write lock that was passed to the constructor.
Relocks an unlocked lock.
See alsounlock().
Unlocks the lock associated with this locker.
See alsoQReadWriteLock::unlock().
© 2016 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of theGNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.