Qt下继承于QObject创建的线程

Qt线程

  • 线程创建方法
  • 示例

线程创建方法

Qt下创建线程的方法有两种:
一种是通过继承QThread,并重写run()函数,在run()函数中,编写线程所做的事情,在需要线程的文件中,创建线程对象,并通过start()函数启动线程,运行run()函数。
另一种是继承QObject类之后,在此类中编写相应的信号和槽函数,在需要线程的类中,创建QThread类的指针和此类的指针,之后,通过函数movetoThread()函数实现线程的转移,关联信号槽后,同过QThread的指针调用start()函数开始线程。

示例

实现的功能是:在下面的界面上,程序运行起初,开始线程按钮和停止线程按钮都是置灰状态,无法使用,点击选择文件路径的按钮之后,弹出一个文件选择对话框,选择的文件路径显示在右侧的TextEdit控件中,此时开始线程按钮可以使用,点击开始线程按钮后,开始线程的按钮变为置灰,停止线程按钮变为可用,PlainTextEdit文本中开始显示所选文件的内容,并不断的显示其内容n遍,在这种状态下直接关闭对话框,即没有停止线程的情况下,关闭对话框,保证程序不奔溃,另一种,可点击停止线程按钮,关闭线程,PlainTextEdit中便不再继续输出文本,然后关闭对话框,程序正常结束。
界面如下图所示:
在这里插入图片描述
界面上对象与类的对应关系,如下图:
在这里插入图片描述
继承QObject的类mythread的代码:
mythread.h

#ifndef MYTHREAD_H
#define MYTHREAD_H#include <QThread>
#include <QObject>
class QNetworkReply;class MyThread : public QObject
{Q_OBJECT
public:explicit MyThread(QObject *parent = nullptr);void SetNetworkReply(QNetworkReply *reply);
public slots:void replyFinished();
//     void slotTransferNetReply(QNetworkReply *reply);
signals:void signDisplayString( QString str);private:QNetworkReply *m_reply;
};#endif // MYTHREAD_H

mythread.cpp

#include "mythread.h"
#include <QFile>
#include <QDebug>
#include <QThread>MyThread::MyThread(QObject *parent) : QObject(parent)
{m_Statua = false;m_bEndThread = false;
}
MyThread::~MyThread()
{m_Statua = false;m_bEndThread = false;
}void MyThread::slotGetFileContent()
{m_bEndThread = true;while(!m_Statua){QString strFileContent;strFileContent = GetFileContent();if(strFileContent.isEmpty()){return ;}emit signFileContent(strFileContent);       QThread::sleep(1);//不加等待1s会出现线程读数据太快,界面还没来得及写,而导致崩溃}m_bEndThread = false;
}void MyThread::slotFilePath(const QString &strPath)
{m_strFilePath = strPath;
}void MyThread::StopThread()
{m_Statua = true;
}QString MyThread::GetFileContent()
{QString str;QFile file(m_strFilePath);if(!file.exists()){qDebug()<<QString("%1文件不存在").arg(m_strFilePath)<<endl;return str;}if(!file.open(QIODevice::ReadOnly|QIODevice::Text)){qDebug()<<m_strFilePath<<"文件打开失败"<<endl;return str;}str = file.readAll();file.close();//为文件打开后记得关闭return str;
}

界面类dialog的代码:
dialog.h

#ifndef DIALOG_H
#define DIALOG_H#include <QDialog>
#include <QThread>
#include "mythread.h"namespace Ui {
class Dialog;
}class Dialog : public QDialog
{Q_OBJECTpublic:explicit Dialog(QWidget *parent = nullptr);~Dialog();void closeEvent(QCloseEvent *event);
signals:void signFilePath(const QString &strPath);
public slots:void slotFileContent(const QString &str);
private slots:void on_pushButton_clicked();void on_pushButtonStart_clicked();void on_pushButtonStop_clicked();private:Ui::Dialog *ui;QThread *thread;MyThread *myThread;
//    QThread thread;
//    MyThread myThread;
};#endif // DIALOG_H

dialog.cpp

#include "dialog.h"
#include "ui_dialog.h"
#include <QFileDialog>
#include <QDebug>Dialog::Dialog(QWidget *parent) :QDialog(parent),ui(new Ui::Dialog)
{ui->setupUi(this);ui->pushButtonStop->setEnabled(false);ui->pushButtonStart->setEnabled(false);myThread = new MyThread;thread = new QThread(this);connect(ui->pushButtonStart,SIGNAL(clicked()),this,SLOT(on_pushButtonStart_clicked()));connect(ui->pushButtonStop,SIGNAL(clicked()),this,SLOT(on_pushButtonStop_clicked()));connect(this,&Dialog::signFilePath,myThread,&MyThread::slotFilePath);
//    connect(this,&Dialog::signFilePath,&myThread,&MyThread::slotFilePath);//   connect(&myThread,&MyThread::signFileContent,this,&Dialog::slotFileContent);
}Dialog::~Dialog()
{delete ui;
}void Dialog::closeEvent(QCloseEvent *event)//防止线程正在运行时,关闭进程导致的崩溃
{if(thread->isRunning()){myThread->StopThread();thread->quit();thread->wait();}
//    if(thread.isRunning())
//    {
//        myThread.StopThread();//        while(myThread.m_bEndThread)
//        {
//            qDebug()<<"-->closeEvent";
//            QThread::sleep(1);
//        }
//        qDebug()<<"-->closeEvent thread end";
//        thread.quit();
//        thread.wait();
//    }event->accept();
}void Dialog::slotFileContent(const QString &str)
{ui->plainTextEdit->appendPlainText(str);
}void Dialog::on_pushButton_clicked()
{QString strCurPath = QDir::currentPath();QString strFileter = QString("源文件(*.h *.cpp);;文本文件(*.txt);;所有文件(*.*)");//QString strFilePath = QFileDialog::getOpenFileName(this,tr("选择文件"),strCurPath,strFileter);if(strFilePath.isEmpty()){return ;}ui->textEdit->setText(strFilePath);emit signFilePath(strFilePath);ui->pushButton->setEnabled(false);ui->pushButtonStart->setEnabled(true);
}void Dialog::on_pushButtonStart_clicked()
{ui->pushButtonStop->setEnabled(true);ui->pushButtonStart->setEnabled(false);
//    myThread = new MyThread;
//    thread = new QThread(this);myThread->moveToThread(thread);//定义为指针就没有问题
//    myThread.moveToThread(&thread);connect(thread,&QThread::started,myThread,&MyThread::slotGetFileContent);connect(thread,&QThread::finished,myThread,&QObject::deleteLater);connect(myThread,&MyThread::signFileContent,this,&Dialog::slotFileContent);thread->start();
//    connect(&thread,&QThread::started,&myThread,&MyThread::slotGetFileContent);
//    connect(&thread,&QThread::finished,&myThread,&QObject::deleteLater);
//    connect(&myThread,&MyThread::signFileContent,this,&Dialog::slotFileContent);
//    thread.start();
}void Dialog::on_pushButtonStop_clicked()
{if(thread->isRunning()){myThread->StopThread();thread->quit();//定义为变量会出现停止线程的时候没有停止,且加上quit()函数后会卡死,直接关闭对话框会崩溃,提示线程正在运行被关闭了thread->wait();ui->pushButton->setEnabled(true);ui->pushButtonStop->setEnabled(false);}
//    if(thread.isRunning())
//    {
//        myThread.StopThread();
//        while(myThread.m_bEndThread)
//        {
//            qDebug()<<"-->clos button";
//            QThread::sleep(1);
//        }
//        qDebug()<<"-->clos button thread end";
//        thread.exit();//定义为变量会出现停止线程的时候没有停止,且加上quit()函数后会卡死,直接关闭对话框会崩溃,提示线程正在运行被关闭了
//        //thread.wait();
//        ui->pushButton->setEnabled(true);
//        ui->pushButtonStop->setEnabled(false);
//    }
}

主函数main函数的代码没变:

#include "dialog.h"
#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);Dialog w;w.show();return a.exec();
}

初次尝试,第一此定义的QThread对象和继承于QObject的类的对象,没有用指针,但是不知为啥,总是会程序奔溃,最后采用了指针,程序可以正常运行。求一份定义变量的情况下,此程序可以正常运行的指导,望各位同仁不吝赐教。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/524314.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

入门篇|学渣是如何自学数据结构的?

戳蓝字“CSDN云计算”关注我们哦&#xff01;作者 | 小鹿来源 | 一个不甘平凡的码农写在前边-------------------------------------------今天呢&#xff0c;我想简单的分享一下半年来自学数据结构与算法学习方法和技巧。写这篇文章主要目的还是重在让刚刚接触数据结构的读者…

Qt下简单的文件读取

此示例只是一个简单的文件的打开&#xff0c;读取&#xff0c;文件内容的加载&#xff0c;望共勉。 界面效果展示 代码实现 dialog.h #ifndef DIALOG_H #define DIALOG_H#include <QDialog>namespace Ui { class Dialog; }class Dialog : public QDialog {Q_OBJECTpub…

趣挨踢 | 用大数据扒一扒蔡徐坤的真假流量粉

戳蓝字“CSDN云计算”关注我们哦&#xff01;作者&#xff1a;AlfredWu 转自&#xff1a; Alfred数据室前段时间央视新闻公开披露流量明星数据造假。作为一名数据猿&#xff0c;我们秉着好奇心点开了NBA新春贺岁形象大使蔡徐坤的微博&#xff0c;发现他的微博转发量除了最新一条…

Windows OpenGL ES 图像曝光度调节

零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 转场 零基础 OpenGL ES 学习路线推荐…

C++中析构函数

析构函数&#xff1a; 1.析构函数不能被重载&#xff1b; 2.析构函数可以是虚函数&#xff1b; 3.析构函数没有参数&#xff0c;没有返回值&#xff1b; 4.当类对象的生命周期结束&#xff0c;系统会自动调用析构函数&#xff1b; 5.若没有显式的析构函数&#xff0c;系统会调用…

Jenkins进阶系列之——07更改Jenkins的主目录

Jenkins进阶系列之——07更改Jenkins的主目录 参考链接&#xff1a; https://blog.csdn.net/pansaky/article/details/80749567 Jenkins默认会存放在用户主目录下的.jenkins文件夹中 如&#xff1a;Linux root用户&#xff1a;/root/.jenkins 注意&#xff1a;这是linux版本的…

Windows OpenGL 图像曝光度调节

目录 一.OpenGL 图像曝光度调节 1.原始图片2.效果演示 二.OpenGL 图像曝光度调节源码下载三.猜你喜欢 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基础 Op…

kubernetes精华问答 | Swarm和K8S的共同点有哪些?

kubernetes&#xff0c;简称K8s&#xff0c;是用8代替8个字符“ubernete”而成的缩写。是一个开源的&#xff0c;用于管理云平台中多个主机上的容器化的应用&#xff0c;Kubernetes的目标是让部署容器化的应用简单并且高效&#xff08;powerful&#xff09;,Kubernetes提供了应…

The server quit without updating PID file

The server quit without updating PID file (/usr/local/var/mysql/bogon.pid) 今天网站web页面提交内容到数据库&#xff0c;发现出错了&#xff0c;一直提交不了&#xff0c;数找了下原因&#xff0c;发现数据写不进去&#xff01;第一反应&#xff0c;重启mysql数据库&…

开发者如何快速精简容器云镜像?| 技术头条

戳蓝字“CSDN云计算”关注我们哦&#xff01;作者&#xff1a;阿木接触过容器云或者用过容器的同学一般都会遇到容器镜像占用空间很大的问题&#xff0c;遇到此类问题的时候大部分同学可能更加习惯于为容器的镜像仓库增加磁盘空间&#xff0c;当然这种方式无可厚非&#xff0c;…

Linux环境 Jenkins集成构建SonarQube

参考链接&#xff1a; https://www.linuxhub.org/?p4450 https://blog.51cto.com/damaicha/2118766 https://max.book118.com/html/2019/0107/8067110025002000.shtmJenkins集成构建SonarQube 一、前提准备 应用服务器apache-tomcat-9.0.20.tar.gzjenkinsjenkins.warmysql版…

Windows OpenGL ES 图像对比度调节

目录 一.OpenGL ES图像对比度调节 1.原始图片2.效果演示 二.OpenGL ES 图像对比度调节源码下载三.猜你喜欢 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基…

dubbo之.xml配置文件报错

【dubbo之.xml配置文件报错】Multiple annotations found at this line: - cvc-complex-type.2.4.c: The 异常现象&#xff1a; 1.dubbo配置xml文件报错 “Multiple annotations found at this line:- cvc-complex-type.2.4.c: The matching wildcard is strict, but no decl…

验证电脑的字节序

字节序的分类 大端字节序&#xff1a;低地址存高位&#xff0c;高地址存底位&#xff0c;网络字节序又叫大端端字节序&#xff1b; 小端字节序&#xff1a;低地址存地位&#xff0c;高地址存高位&#xff1b; 验证示例 记录2个示例来说明电脑采用的大端字节序还是小端字节序…

刚刚出新的Kubernetes 却曝出了“高危”安全漏洞;亚马逊将推免费新闻视频服务,对标苹果 | 极客头条...

关注并标星星CSDN云计算每周三次&#xff0c;打卡即read更快、更全了解泛云圈精彩newsgo go go 被宣布取消的AirPower&#xff08;图片来源网络&#xff09;【4月1日 星期一】云の声音5G最极致的应用领域应该是8K电视。——富士康科技集团副总裁、富士康企业大学创校校长 陈振国…

Maven实战手册

一、maven的作用&#xff1a; 1.1jar包的统一依赖管理&#xff0c;节省空间1.2项目的一键构建 二、Maven能做什么&#xff1f; 2.1编译 测试(junit) 运行 打包 部署 三、Maven的安装配置署 3.1下载安装3.2 官网链接&#xff1a;http://maven.apache.org/download.cgi 3.3下…

Windows OpenGL 图像对比度调节

零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 基础 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 特效 零基础 OpenGL ES 学习路线推荐 : OpenGL ES 学习目录 >> OpenGL ES 转场 零基础 OpenGL ES 学习路线推荐…

大端字节序与小端字节序的转换

逐步加深对字节操作的理解&#xff0c;记录一下大端字节序与小端字节序的转换&#xff0c;开发环境是vs2010&#xff0c;项目类型是控制台输出程序&#xff0c;下面是代码实现&#xff1a; // ByteOrder_demo.cpp : 定义控制台应用程序的入口点。 //#include "stdafx.h&q…

2019年技术盘点微服务篇(一) | 程序员硬核评测

戳蓝字“CSDN云计算”关注我们哦&#xff01;作者&#xff1a;孙浩峰过去几年来&#xff0c;“微服务架构”方兴未艾&#xff0c;尽管这种架构风格没有确切的定义&#xff0c;但我们已经看到许多项目凭借此架构取得了积极的结构&#xff0c;因此对于许多开发者来说&#xff0c;…