Qt:Документация 4.3.2/qwritelocker

Материал из Wiki.crossplatform.ru

Перейти к: навигация, поиск
40px Внимание: Актуальная версия перевода документации находится здесь

__NOTOC__

Image:qt-logo.png

Главная · Все классы · Основные классы · Классы по группам · Модули · Функции

Image:trolltech-logo.png

Содержание

[править] QWriteLocker Class Reference
[модуль QtCore ]

The QWriteLocker aclass is a convenience class that simplifies locking and unlocking read-write locks for write access. More...

 #include <QWriteLocker>

Note: All the functions in this class are thread-safe.

[править] Открытые функции


[править] Подробное описание

The QWriteLocker class is a convenience class that simplifies locking and unlocking read-write locks for write access.

The purpose of QWriteLocker (and QReadLocker is to simplify QReadWriteLock locking and unlocking. Locking and unlocking statements or in exception handling code is error-prone and difficult to debug. QWriteLocker can be used in such situations to ensure that the state of the lock is always well-defined.

Here's an example that uses QWriteLocker to lock and unlock a read-write lock for writing:

 QReadWriteLock lock;
 
 void writeData(const QByteArray &amp;data)
 {
     QWriteLocker locker(&amp;lock);
     ...
 }

It is equivalent to the following code:

 QReadWriteLock lock;
 
 void writeData(const QByteArray &amp;data)
 {
     locker.lockForWrite();
     ...
     locker.unlock();
 }

The QMutexLocker documentation shows examples where the use of a locker object greatly simplifies programming.

See also QReadLocker and QReadWriteLock.


[править] Описание функций-членов

[править]
QWriteLocker::QWriteLocker ( QReadWriteLock * lock )

Constructs a QWriteLocker and locks lock for writing. The lock will be unlocked when the QWriteLocker is destroyed. If lock is zero, QWriteLocker does nothing.

See also QReadWriteLock::lockForWrite().

[править]
QWriteLocker::~QWriteLocker ()

Destroys the QWriteLocker and unlocks the lock that was passed to the constructor.

See also QReadWriteLock::unlock().

[править]
QReadWriteLock * QWriteLocker::readWriteLock () const

Returns a pointer to the read-write lock that was passed to the constructor.

[править]
void QWriteLocker::relock ()

Relocks an unlocked lock.

See also unlock().

[править]
void QWriteLocker::unlock ()

Unlocks the lock associated with this locker.

See also QReadWriteLock::unlock().


Copyright © 2007 Trolltech Trademarks
Qt 4.3.2