Qt文档阅读笔记|Qt工作笔记-QMutexLocker的使用(抛出异常也能解锁)
生活随笔
收集整理的這篇文章主要介紹了
Qt文档阅读笔记|Qt工作笔记-QMutexLocker的使用(抛出异常也能解锁)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
目錄
?
官方解析
栗子
官方解析
重點如下:
1.QMutexLocker比QMutex的lock與unlock更加方便;
2.當函數生存周期結束后QMutexLocker會自動unlock;
3.如果加鎖的部分拋出了異常,使用QMutex就無法unlock,而使用QMutexLocker可以到達解鎖的效果;
4.QMutexLocker可以調用他傳進來的QMutex對象,調用這個函數mutex();
?
栗子
使用原始的QMutex,拋出異常后不會進行解鎖,如下代碼:
#include <QString> #include <QMutex> #include <QDebug>//一般互斥鎖都定義到.cpp內外,或者為一個成員,不會在函數中定義 QMutex mutex;void tryThrowFunction(){mutex.lock();int judgeValue = 0;switch(judgeValue){case 0:throw "error ..........";break;default:qDebug() << "switch finished!";}mutex.unlock(); }int main(void) {try{tryThrowFunction();}catch(const char *err){qDebug() << err;}return 0; }運行截圖如下(Qt還提示,鎖沒解除):
?
使用QMutexLocker后運行截圖如下:
源碼如下:
#include <QString> #include <QMutex> #include <QMutexLocker> #include <QDebug>//一般互斥鎖都定義到.cpp內外,或者為一個成員,不會在函數中定義 QMutex mutex;void tryThrowFunction(){QMutexLocker locker(&mutex);int judgeValue = 0;switch(judgeValue){case 0:throw "error ..........";break;default:qDebug() << "switch finished!";}}int main(void) {try{tryThrowFunction();}catch(const char *err){qDebug() << err;}return 0; }?
總結
以上是生活随笔為你收集整理的Qt文档阅读笔记|Qt工作笔记-QMutexLocker的使用(抛出异常也能解锁)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 谁动了你的主机-Windows“唤醒”和
- 下一篇: Qt文件编码转换工具(三) Qt界面设计