您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關Qt5.9如何實現簡單的多線程,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
Qt開啟多線程,主要用到類QThread。有兩種方法,第一種用一個類繼承QThread,然后重新改寫虛函數run()。當要開啟新線程時,只需要實例該類,然后調用函數start(),就可以開啟一條多線程。第二種方法是繼承一個QObject類,然后利用moveToThread()函數開啟一個線程槽函數,將要花費大量時間計算的代碼放入該線程槽函數中。第二種方法可以參考我寫的另一篇博客:http://www.mlszssj.com/article/223796.htm
下面我總結的主要是第一種方法。(注意:只有在run()函數里面才是新的線程,所有復雜邏輯都應該在run()函數里面做。當run()函數運行完畢后,該線程生命周期結束。)
創建多線程步驟如下:
a1新建一個類MyThread,基類為QThread。
a2重寫類MyThread的虛函數void run();,即新建一個函數protected void run(),然后對其進行定義。
a3在需要用到多線程的地方,實例MyThread,然后調用函數MyThread::start()后,則開啟一條線程,自動運行函數run()。
a4當停止線程時,調用MyThread::wait()函數,等待線程結束,并且回收線程資源。
1.1新建一個widget工程,不要勾選ui界面。然后分別在mythread.h,mythread.cpp,widget.h,widget.cpp,main.cpp分別添加如下代碼。
mythread.h
#ifndef MYTHREAD_H #define MYTHREAD_H #include <QThread> class MyThread : public QThread { public: MyThread(); void closeThread(); protected: virtual void run(); private: volatile bool isStop; //isStop是易失性變量,需要用volatile進行申明 }; #endif // MYTHREAD_H
mythread.cpp
#include "mythread.h" #include <QDebug> #include <QMutex> MyThread::MyThread() { isStop = false; } void MyThread::closeThread() { isStop = true; } void MyThread::run() { while (1) { if(isStop) return; qDebug()<<tr("mythread QThread::currentThreadId()==")<<QThread::currentThreadId(); sleep(1); } }
widget.h
#ifndef WIDGET_H #define WIDGET_H #include <QWidget> #include <mythread.h> #include <QPushButton> #include <QVBoxLayout> #include <QMutex> class Widget : public QWidget { Q_OBJECT public: Widget(QWidget *parent = 0); ~Widget(); void createView(); private slots: void openThreadBtnSlot(); void closeThreadBtnSlot(); void finishedThreadBtnSlot(); // void testBtnSlot(); private: QVBoxLayout *mainLayout; MyThread *thread1; }; #endif // WIDGET_H
widget.cpp
#include "widget.h" #include <QDebug> #include <windows.h> Widget::Widget(QWidget *parent) : QWidget(parent) { createView(); } void Widget::createView() { /*添加界面*/ QPushButton *openThreadBtn = new QPushButton(tr("打開線程")); QPushButton *closeThreadBtn = new QPushButton(tr("關閉線程")); mainLayout = new QVBoxLayout(this); mainLayout->addWidget(openThreadBtn); mainLayout->addWidget(closeThreadBtn); mainLayout->addStretch(); connect(openThreadBtn,SIGNAL(clicked(bool)),this,SLOT(openThreadBtnSlot())); connect(closeThreadBtn,SIGNAL(clicked(bool)),this,SLOT(closeThreadBtnSlot())); /*線程初始化*/ thread1 = new MyThread; connect(thread1,SIGNAL(finished()),this,SLOT(finishedThreadBtnSlot())); } void Widget::openThreadBtnSlot() { /*開啟一個線程*/ thread1->start(); qDebug()<<"主線程id:"<<QThread::currentThreadId(); } void Widget::closeThreadBtnSlot() { /*關閉多線程*/ thread1->closeThread(); thread1->wait(); } void Widget::finishedThreadBtnSlot() { qDebug()<<tr("完成信號finished觸發"); } Widget::~Widget() { }
main.cpp
#include "widget.h" #include <QApplication> int main(int argc, char *argv[]) { QApplication a(argc, argv); Widget w; w.resize(960,640); w.show(); return a.exec(); }
1.2程序構建和運行后,結果如下圖所示:
以上就是Qt5.9如何實現簡單的多線程,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。