#include <qmutex.h>
公有成员
-
QMutex ( bool recursive = FALSE )
-
virtual ~QMutex ()
-
void lock ()
-
void unlock ()
-
bool locked ()
-
bool tryLock ()
详细描述
QMutex类提供的是线程之间的访问顺序化。QMutex的目的是保护一个对象、数据结构或者代码段,所以同一时间只有一个线程可以访问它。(在Java术语中,它和同步关键字“synchronized”很相似)。例如,这里有一个方法打印给用户两条消息:
void someMethod() { qDebug("Hello"); qDebug("World"); }
如果同时在两个线程中调用这个方法,结果的顺序将是:
Hello Hello World World
如果你使用了一个互斥量:
QMutex mutex; void someMethod() { mutex.lock(); qDebug("Hello"); qDebug("World"); mutex.unlock(); }
用Java的术语,这段代码应该是:
void someMethod() { synchronized { qDebug("Hello"); qDebug("World"); } }
然后同一时间只有一个线程可以运行someMethod并且消息的顺序也一直是正确的。当然,这只是一个很简单的例子,但是它适用于任何需要按特定频率发生的情况。
但你在一个线程中调用lock(),其它线程将会在同一地点试图调用lock()来阻塞,知道这个线程调用unlock()之后其它线程才会获得这个锁。lock()的一种非阻塞选择是tryLock()。
成员函数文档
QMutex::QMutex ( bool recursive = FALSE )
构造一个新的互斥量。这个互斥量是在没有锁定的状态下创建的。如果 recursive 为真,就构造一个递归互斥量,如果 recursive 为假(默认值),就构造一个普通互斥量。对于一个递归互斥量,一个线程可以锁定一个互斥量多次并且只有在相同数量的 unlock ()调用之后,它才会被解锁。QMutex::~QMutex () [虚]
销毁这个互斥量。void QMutex::lock ()
试图锁定互斥量。如果另一个线程已经锁定这个互斥量,那么这次调用将 阻塞 直到那个线程把它解锁。bool QMutex::locked ()
如果互斥量被另一个线程锁定了,返回真,否则返回假。警告:由于不同平台上递归互斥量的实现不同,所以从以前锁定这个互斥量的同一个线程上调用这个函数可能会返回未定义的结果。
bool QMutex::tryLock ()
试图锁定互斥量。如果锁被得到,这个函数返回真。如果另一个进程已经锁定了这个互斥量,这个函数返回假,而不是一直等到这个锁可用为止,比如,它不是阻塞的。在另一个线程可以成功锁定它之前,这个锁必须被调用unlock()来解锁。
也可以参考lock()、unlock()和locked()。