以下内容来源:
QT5 开发及实例(第二版)
实现线程互斥与同步常用的类 有
QMutex,QMutexLocker,QReadWriterLocker,QReadLocker,QWriteLocker,QSemaphore,QWaitCondition
EG:
class Key:
{
public:
Key(){key = 0;}
int createKey(){++key;return key;}
int value() const{return key;}
private:
int key;
}
如果key值等于0,线程一和线程二同时将0载入寄存器,执行+1操作写入主存,则结果是两个线程的执行结果将互相覆盖,实际上仅进行了1次+1的操作。
这时候 我们需要将线程串行执行
1.互斥量
互斥量可通过QMutex或者QMutexLocker类实现
QMutex类
QMutex类对互斥量的处理,它被用来保护一段临界区代码,即每次只允许一个线程访问这段代码
class Key:
{
public:
Key(){key = 0;}
int createKey(){mutex.lock();++key;return key;mutex.unlock();}
int value() const{mutex.lock();return key;mutex.unlock();}
private:
int key;
QMutex mutex;
}
存在问题 ruturn之后 unlock()永远不会执行
QMutexLocker
QMutexLocker简化了互斥量的处理,在构造函数中接受一个QMutex对象作为参数并将其锁定,在析构函数中解锁互斥量,这样就解决了上述问题。
class Key:
{
public:
Key(){key = 0;}
int createKey(){QMutexLocker.locker(&mutex);++key;return key;}
int value() const{QMutexLocker.locker(&mutex);return key;}
private:
int key;
QMutex mutex;
}
实际应用中,使用QMutexLocker类,通常只需要这一条语句,大大简化了编程的复杂程度。
信号量
信号量可以理解为对互斥量功能的扩展,互斥量只能锁定一次而信号量可以锁定多次,它可以用来保护一定数量的程序资源。
待续…