Qt之QMutex

时间:2023-03-10 07:13:47
Qt之QMutex
  • 概述

QMutex 类使得线程之间可序列化,文档中的描述为provides access serialization between threads

它被设计的初衷是用来保护一个对象、数据结构、代码段、使得它们在同一一时刻,只有一个线程有访问权限(这有点跟java中的synchronized关键字类似)。

  • 场景

比如我们有如下的代码片段:

 int number = ;

 void method1()
{
number *= ;
number /= ;
} void method2()
{
number *= ;
number /= ;
}

假如method1()和method2()不在同一线程中,则nunber就成为临界资源,这个时候,为了保证在同一时刻只有一个线程能够使用number,就可以使用Qmutex,具体代码如下:

 QMutex mutex;
int number = ; void method1()
{
mutex.lock();
number *= ;
number /= ;
mutex.unlock();
} void method2()
{
mutex.lock();
number *= ;
number /= ;
mutex.unlock();
}
  • 提供的成员变量以及成员方法

public type:

  1. enum RecursionMode{Recursive,NonRecursive}

RecursionMode有两种值,分别是1和0,1表示Recursive 在这个模式下,一个线程可以lock多次相同的互斥量,直到相应数量的unlock被调用才能被解锁;0表示一个线程仅可以锁互斥量一次,不可递归。

public functions:

  1. QMutex(RecursionMode mode = NonRecursive)

构造函数,构造一个新的mutex,这个mutex创建之后处于unlock状态。RecursionMode的默认值为0

  1. bool isRecursive()

如果mutex为递归,则返回true。

  1. void lock()

给mutex加锁,如果mutex被另一个线程加了锁,则阻塞直到另一个线程释放锁。处于0模式时将其递归加锁会造成死锁,如果处于1模式,则可以对其多重加锁。

  1. bool tryLock(int timeout = 0)

试着去给一个互斥量加锁,如果这个互斥量没被锁,则返回true,如果被锁,则等待timeout时间,等待其他线程释放锁,当timeout为负数时,一直等待。

  1. void unlock()

给mutex解锁,给一个未lock的mutex解锁,将有不可预知的结果,尝试去给不同的线程中的mutex解锁,会导致错误。