Qt:多线程编程

本文介绍了Qt中多线程的实现方式,包括创建线程、互斥与同步(QMutex、QMutexLocker等),以及生产者消费者问题的解决。还讨论了线程的优先级、死锁、线程本地存储和Qt线程机制,如GUI线程与非GUI线程间的通信、线程安全的类和事件处理。
摘要由CSDN通过智能技术生成
一、创建线程:只需子类化QThread并重新实现它的run()函数就可以了。
//QThread类的start()函数启动run(),可在程序的start()槽中利用QThread子类调用start()。
二、Qt为实现线程的互斥和同步提供了几个常用类:
QMutex,QMutexLocker,QReadWriteLocker,QReadLocker,QWriteLocker,QSemaphore,QWaitCondition
1、mutex.lock();mutex.unlock();mutex.tryLock();
eg:
int createKey(){
mutex.locak();
++key;
return key;
mutex.unlock(); //永远无法执行!!!用QMutexLocker
}
QMutexLocker类在构造函数中接受一个QMutex对象作为参数并将其锁定,在析构函数中解锁这个互斥量。
int createKey(){
QMutexLocker locker(&mutex);
return key;
}//locker作为局部变量在函数退出时结束其作用域,从而自动对互斥量mutex解锁。
/********************************************************************************************************/
2、互斥量只能锁定一次而信号量可以获取多次,它可以用来保护一定数量的同种资源。
semaphore.acquire(n);//用于获取n个资源,但没有足够的资源时调用者将被阻塞直到有足够的可用资源。
semaphore.release(n);semaphore.tryAcquire(n);
生产者消费者解决方案1:
QSemaphore freeBytes(BufferSize);//可被生产者填充的
QSemaphore usedBytes(0);  //可被消费者读取的
class Producer : public QThread{
public:
    void run();
};
void Producer::run(){
    for(int i = 0; i < DataSize; ++i){
        freeBytes.acquire();
        buffer[i%BufferSize] = (i % BufferSize);
        usedBytes.release();
    }
}
class Consumer : public QThread{
public:
    void run();
};
void Consumer::run(){
    for(int i = 0; i < DataSize; ++i){
        usedBytes.acquir
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值