虚拟网站规划与设计济南建筑设计公司
- 作者: 五速梦信息网
- 时间: 2026年04月20日 07:05
当前位置: 首页 > news >正文
虚拟网站规划与设计,济南建筑设计公司,上海十大外贸公司,网站建设心得8000字Qt互斥锁【QMutex】的使用、QMutexLocker的使用 Chapter1 Qt互斥锁(QMutex)的使用、QMutexLocker的使用一、QMutexLocker和QMutex实现示例图二、QMutex和QMutexLocker的关系#xff08;个人理解#xff09;三、QMutex使用和QMutexLocker使用1.QMutex的使用2.QMutexLocker的使… Qt互斥锁【QMutex】的使用、QMutexLocker的使用 Chapter1 Qt互斥锁(QMutex)的使用、QMutexLocker的使用一、QMutexLocker和QMutex实现示例图二、QMutex和QMutexLocker的关系个人理解三、QMutex使用和QMutexLocker使用1.QMutex的使用2.QMutexLocker的使用 四、检验QMutexLocker是否将传入的互斥锁锁定1.操作解释2.CMoveFuncClass使用moveToThread实现使用QMutexLocker3.CThread类继承QThread实现单纯使用QMutex4.CMainWindow调用类 总结相关文章 Chapter1 Qt互斥锁(QMutex)的使用、QMutexLocker的使用 原文链接https://blog.csdn.net/wj584652425/article/details/123585126 一、QMutexLocker和QMutex实现示例图 下图为检测QMutexLocker是否上锁成功的示例图两个线程使用同一个QMutex源码在文章第四节源码含详细注释。 下图为不同QMutex运行时的效果该图表明两个线程无关并非sleep影响了另一个线程的运行 二、QMutex和QMutexLocker的关系个人理解 互斥锁QMutex在使用时需要在进入和结束的时候使用对应的函数锁定和解锁。在简单的程序中还好但是在结构复杂的程序中因为需要手动锁定和解锁很容易忽略细节而出现问题于是为了应对这种情况QMutexLocker便诞生了为了简化简化互斥锁的锁定和解锁。 QMutexLocker通常创建为局部变量QMutexLocker在创建时传入一个并未锁定若是锁定可用relock重新锁定或unlock解锁的QMutex指针变量并且会将QMutex变量锁定在释放时会将QMutex变量解锁。QMutexLocker创建时将传入的QMutex锁定释放时将传入的QMutex解锁 三、QMutex使用和QMutexLocker使用 1.QMutex的使用 void CThread::run() {//互斥锁锁定m_mutex-lock();//输出当前线程的线程IDqDebug() QThread::currentThreadId();//互斥锁解锁m_mutex-unlock(); }2.QMutexLocker的使用 void CThread::run() {//创建QMutexLocker的局部变量并将类中互斥锁指针传入此处互斥锁被locker锁定QMutexLocker locker(m_mutex);qDebug() QThread::currentThreadId();//当locker作用域结束locker将互斥锁解锁 }通过1、2的代码比较我们会发现QMutexLocker的代码中没有手动调用锁定和解锁由此可看出MutexLocker简化了互斥锁的锁定和解锁。 四、检验QMutexLocker是否将传入的互斥锁锁定 1.操作解释 使用两种实现方法完全不同线程测试 两个线程使用同一个互斥锁 一个线程使用QMutexLocker一个线程单纯使用QMutex 2.CMoveFuncClass使用moveToThread实现使用QMutexLocker CMoveFuncClass.h #ifndef CMOVEFUNCCLASS_H #define CMOVEFUNCCLASS_H#include QObject #include QMutexclass CMoveFuncClass : public QObject {Q_OBJECT public:explicit CMoveFuncClass(QObject *parent nullptr);~CMoveFuncClass();void setMutex(QMutex *mutex);public slots:void doSomething();private:QMutex * m_mutex; //定义一个互斥锁变量 };#endif // CMOVEFUNCCLASS_HCMoveFuncClass.cpp #include CMoveFuncClass.h#include QDebug #include QThreadCMoveFuncClass::CMoveFuncClass(QObject *parent): QObject(parent) { }CMoveFuncClass::~CMoveFuncClass() { }void CMoveFuncClass::doSomething() {//创建QMutexLocker的局部变量并将类中互斥锁指针传入此处互斥锁被locker锁定QMutexLocker locker(m_mutex);qDebug() 我的实现方法为moveToThread 开始3秒睡眠 使用QMutexLocker;qDebug() 线程ID QThread::currentThreadId();QThread::sleep(3); //设置线程睡眠3秒单位为秒qDebug() 我的实现方法为moveToThread 线程运行完成结束睡眠\n\n;//当locker作用域结束locker将互斥锁解锁 }void CMoveFuncClass::setMutex(QMutex *mutex) {m_mutex mutex; }3.CThread类继承QThread实现单纯使用QMutex CThread.h #ifndef CTHREAD_H #define CTHREAD_H#include QObject #include QThread #include QMutex #include QWaitConditionclass CThread : public QThread {Q_OBJECT public:explicit CThread(QObject *parent nullptr);~CThread();void run();void setMutex(QMutex *mutex);private:QMutex * m_mutex; //定义一个线程锁变量};#endif // CTHREAD_HCThread.cpp #include CThread.h #include QDebugCThread::CThread(QObject *parent): QThread(parent) { }CThread::~CThread() { }void CThread::run() {//互斥锁上锁m_mutex-lock();qDebug() 我的实现方法为继承QThread 开始3秒睡眠 单纯使用QMutex;qDebug() 线程ID QThread::currentThreadId();QThread::sleep(3); //设置线程睡眠3秒单位为秒qDebug() 我的实现方法为继承QThread 线程运行完成结束睡眠;//互斥锁解锁m_mutex-unlock(); }void CThread::setMutex(QMutex *mutex) {m_mutex mutex; }4.CMainWindow调用类 CMainWindow.h #ifndef CMAINWINDOW_H #define CMAINWINDOW_H#include QMainWindow #include CThread.h #include CMoveFuncClass.hnamespace Ui { class CMainWindow; }class CMainWindow : public QMainWindow {Q_OBJECTpublic:explicit CMainWindow(QWidget *parent 0);~CMainWindow();signals:void startMoveThread();private slots:void on_startBtn_clicked(); //触发方法二函数的信号private:Ui::CMainWindow *ui;CThread *m_cThread; //方法一指针CMoveFuncClass *m_moveFunc; //方法二指针QThread *m_thread; //方法二所移至的线程指针QMutex *m_mutex; //两个线程使用的线程锁 };#endif // CMAINWINDOW_HCMainWindow.cpp #include CMainWindow.h #include ui_CMainWindow.h#include QDebugCMainWindow::CMainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::CMainWindow) {ui-setupUi(this);/方法一/////new出CThread对象m_cThread new CThread;/方法二/////new一个moveToThread的接收线程并启动m_thread new QThread;//new出CMoveFuncClass对象m_thread-start(); //一定记得启动否则运行不了m_moveFunc new CMoveFuncClass;//连接相应信号槽connect(this, CMainWindow::startMoveThread, m_moveFunc, CMoveFuncClass::doSomething);connect(m_thread, QThread::finished, m_moveFunc, QObject::deleteLater);//将对象移至线程m_moveFunc-moveToThread(m_thread);//创建线程共用的互斥锁m_mutex new QMutex;//下方为m_mutex的地方更改为new QMutex则能实现第一节第二张图的效果m_cThread-setMutex(m_mutex);m_moveFunc-setMutex(m_mutex); }CMainWindow::~CMainWindow() {delete m_mutex;delete m_moveFunc;m_thread-exit();m_thread-wait(1);delete m_thread;m_cThread-exit();m_cThread-wait(1);delete m_cThread;delete ui; }void CMainWindow::on_startBtn_clicked() {//通过start启动方法一线程m_cThread-start();//发送信号启动方法二线程emit startMoveThread(); }运行上方的代码第一节第一张效果图可看出使用QMutexLocker的线程首先运行且代码中无锁定和解锁的操作但另外一个线程依然等该线程运行完成后运行由此可看出使用QMutexLocker是实现了互斥锁的锁定和解锁的。 总结 QMutexLocker提供的简化互斥锁锁定和解锁的机制在很多时候时蛮方便的在使用互斥锁的地方使用QMutexLocker会减去许多安全隐患不过在多线程循环输出ABC的时候好像就不适合该方法。所以使用类似的类还得按情况而定 相关文章 启动QThread线程的两种方法含源码注释 Qt互斥锁(QMutex)、条件变量(QWaitCondition)讲解QMutex实现多线程循环输出ABC含源码注释 QSemaphore的使用QSemaphore实现循环输出ABC含源码注释 QRunnable线程、QThreadPool线程池的使用含源码注释 Qt读写锁QReadWriteLock的使用、读写锁的验证含源码注释 Qt读写锁QWriteLocker、QReadLocker的理解和使用含部分源码 Qt之线程运行指定函数含源码注释优化速率 友情提示——哪里看不懂可私哦让我们一起互相进步吧 创作不易请留下一个免费的赞叭 谢谢 o/) 注文章为作者编程过程中所遇到的问题和总结内容仅供参考若有错误欢迎指出。 注如有侵权请联系作者删除
- 上一篇: 虚拟空间怎么做网站目录指向可以做片头的网站
- 下一篇: 虚拟网站建设做网页找什么公司
相关文章
-
虚拟空间怎么做网站目录指向可以做片头的网站
虚拟空间怎么做网站目录指向可以做片头的网站
- 技术栈
- 2026年04月20日
-
虚拟机做局域网网站服务器有免费查企业的软件吗
虚拟机做局域网网站服务器有免费查企业的软件吗
- 技术栈
- 2026年04月20日
-
虚拟机做局域网网站服务器seo排名外包
虚拟机做局域网网站服务器seo排名外包
- 技术栈
- 2026年04月20日
-
虚拟网站建设做网页找什么公司
虚拟网站建设做网页找什么公司
- 技术栈
- 2026年04月20日
-
虚拟物品网站制作模板可以营销的十大产品
虚拟物品网站制作模板可以营销的十大产品
- 技术栈
- 2026年04月20日
-
虚拟主机便宜电商seo优化
虚拟主机便宜电商seo优化
- 技术栈
- 2026年04月20日
