当前位置: 首页 > news >正文

进阶2_1:QT5多线程与定时器共生死

1、在widget.ui中使用 LCD Number控件

注意:若 LCD 控件不是多线程,LCD控件则会瞬间自增到最大的数值,如上图,说明两者都是多线程处理

2、实现方式

1、创建 LCD 控件并修改为 LCD1

2、创建任务类 mytask. h,对任务类添加信号、槽、任务的全局变量

#ifndef MYTASK_H
#define MYTASK_H#include <QObject>class MyTask : public QObject
{Q_OBJECT
public:explicit MyTask (QObject *parent = nullptr);//子线程发送信号
signals:void task2_signal (int i);//子线程接收的槽函数
public slots:void StartTimerSlots ();private:int i=0;//设置为全局变量后,必须为置为0,否则就会出现任意值QString current_date=nullptr;//可以不用赋值,默认被置为NULL
};#endif // MYTASK_H

3、在用户界面 widget. h 添加全局变量(线程变量、任务变量)

#ifndef WIDGET_H
#define WIDGET_H#include <QThread>
#include <QWidget>
#include "mytask.h"QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();void TasksInit();//任务初始化private:Ui::Widget *ui;MyTask *task2; //任务2QThread *mythread;//任务2的线程};
#endif // WIDGET_H

4、在 mytask. cpp 中实现 void StartTimerSlots () 这个函数

#include "mytask.h"
#include <QDebug>
#include <unistd.h>MyTask::MyTask(QObject *parent) : QObject(parent)
{}//任务的槽函数
void MyTask::StartTimerSlots()
{//创建定时器对象QTimer *timer = new QTimer;//定时器超时(每1s)后,自动加1connect(timer, &QTimer::timeout, this, [=]{qDebug() << "子线程定时器触发" << i;emit task2_signal(i++);});timer->start(1000);
}

5、在 wideget. cpp 中

#include "widget.h"
#include "ui_widget.h"
#include <QDebug>
#include <QTimer>
#include "mytask.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);TasksInit();
}Widget::~Widget()
{delete ui;
}/*
功能:对 TCP服务端 进行多线程处理
参数:无参
返回值:无
*/
void Widget::TasksInit()
{MyTask *task2 = new MyTask;QThread *mythread = new QThread;task2->moveToThread(mythread);mythread->start();//创建定时器的开启和关闭connect(mythread, &QThread::started,task2,&MyTask::StartTimerSlots);  // 启动信号connect(mythread, &QThread::finished,task2,&QObject::deleteLater);    // 停止信号connect(mythread, &QThread::finished,mythread,&QObject::deleteLater);    // 停止信号connect(task2,&MyTask::task2_signal,this,[=](int i){ui->LCD1->display(i);},Qt::QueuedConnection);connect(this, &QObject::destroyed, this, [=] {delete task2;mythread->quit();mythread->wait();mythread->deleteLater();});
}

6、解释 wideget. cpp 中执行的步骤

MyTask *task2 = new MyTask; //创建任务对象
QThread *mythread = new QThread; //创建线程对象 
task2->moveToThread(mythread);//将任务放置到线程中
mythread->start();//开启线程
//等待线程开启,执行任务中的槽函数
connect(mythread, &QThread::started,task2,&MyTask::StartTimerSlots);
//等待线程结束,就销毁任务、线程
connect(mythread, &QThread::finished,task2,&QObject::deleteLater);    
connect(mythread, &QThread::finished,mythread,&QObject::deleteLater); 
//等待任务发送信号,用户界面this,接收信号发来的参数i
connect(task2,&MyTask::task2_signal,this,[=](int i){
            ui->LCD1->display(i);//数据i++用于显示LCD
        });
//销毁任务,线程(先销毁任务,在销毁线程)
connect(this, &QObject::destroyed, this, [=] {
    delete task2;
    mythread->quit();
    mythread->wait();
    mythread->deleteLater();
});
注意:task2的销毁事件先于mythread销毁事件
效果:通过上述,实现了,在多线程中使用定时器,定时器与线程同时开启、关闭

相关文章:

  • python:一个代理流量监控的媒体文件下载脚本
  • Docker使用经验-从Image导出dockerfile并进行修改
  • Spark处理过程--案例数据清洗
  • Unity引擎源码-物理系统详解-其二
  • 智能体制作学习笔记1——智能体
  • 软件设计师-下午题-试题4(15分)
  • 深入掌握 Python 切片操作:解锁数据处理的高效密码
  • 基于 Kubernetes 部署容器平台kubesphere
  • 基于网关实现不同网段S7-1200 CPU的通信方法
  • 【Spark分析HBase数据】Spark读取并分析HBase数据
  • 互联网大厂Java求职面试:优惠券服务架构设计与AI增强实践-6
  • Python 之 selenium 打开浏览器指定端口进行接续操作
  • 机器人示教操作
  • excel使用笔记
  • 【2025版】Spring Boot面试题
  • Flutter 开发入门:从一个简单的计数器应用开始
  • Problem E: List练习
  • Linux架构篇、第五章_02git2.49.0分支管理与Gitee的部署
  • 《实现模式》以Golang视角解读 价值观和原则 day 1
  • 【PSINS工具箱】基于工具箱的单独GNSS导航、单独INS导航、两者结合组合导航,三种导航的对比程序。附完整的代码
  • 微软宣布全球裁员约3%:涉及约6000人,侧重经理层
  • 李家超:明日起香港特区护照持有人可免签入境阿联酋
  • 4月新增社融1.16万亿,还原地方债务置换影响后信贷增速超过8%
  • 中国巴西民间推动建立经第三方验证的“森林友好型”牛肉供应链
  • 高培勇:中国资本市场的发展应将预期因素全面纳入分析和监测体系
  • 普京提议于15日在土耳其恢复俄乌直接谈判