线程

QT中的QThread提供了与平台无关的线程,一个QThread代表了一个应用程序中可用独立控制的线程,它与进程中的其他线程共享数据,但是是独立执行的,QThread从run()函数开始执行,默认run()通过exec()来开启事件循环,并在线程内运行一个Qt事件循环。

要创建一个线程,需要继承自QThread,并重新实现run()函数。

示例:

#ifndef MYTHREAD_H
#define MYTHREAD_H

#include <QThread>

class MyThread : public QThread
{
Q_OBJECT
public:
MyThread(QObject* parent = nullptr);

void stop();

protected:

void run() override;//线程启动,执行入口

private:
bool m_isStopped;
};

#endif // MYTHREAD_H


#include "widget.h"
#include "ui_widget.h"

extern int gPies;

Widget::Widget(QWidget *parent) :
QWidget(parent),
ui(new Ui::Widget)
{
ui->setupUi(this);
}

Widget::~Widget()
{
delete ui;
}

void Widget::on_startBtn_clicked()
{
gPies = 0;
m_MyThread1.start();
}

void Widget::on_stopBtn_clicked()
{
m_MyThread1.stop();
}

当多个同类型的线程执行时,有可能发生数据错误。

也就是说,

多线程并发执行的时候,共享数据的准确性是不确定的。

QMutex提供了一个互斥锁(mutex),在任何时间至多有一个线程可以获得mutex,如果一个线程尝试获得mutex,而mutex此时已被锁住,则这个线程会睡眠,直到现在获得mutex的线程对mutex解锁为止。互斥锁常用于对共享数据的访问进行保护。

示例:

void MyThread::run()
{
int i = 0 ;
while(!m_isStopped && i++ < 200){
mutex.lock();
qDebug()<<QString("掉了%1个大饼").arg(++gPies);
mutex.unlock();
}
}