本篇文章給大家分享的是有關Qt5.9如何實現簡單的多線程,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
Qt開啟多線程,主要用到類QThread。有兩種方法,第一種用一個類繼承QThread,然后重新改寫虛函數run()。當要開啟新線程時,只需要實例該類,然后調用函數start(),就可以開啟一條多線程。第二種方法是繼承一個QObject類,然后利用moveToThread()函數開啟一個線程槽函數,將要花費大量時間計算的代碼放入該線程槽函數中。第二種方法可以參考我寫的另一篇博客:http://www.dadijd.cn/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_Hmythread.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_Hwidget.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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。