Qt的QThread、QRunnable和QThreadPool的使用
1.相关描述
随机生产1000个数字,然后进行冒泡排序与快速排序。随机生成类继承QThread类、冒泡排序使用moveToThread方法添加到一个线程中、快速排序类继承QRunnable类,添加到线程池中进行排序。
2.相关界面


3.相关代码
widget.cpp
#include "widget.h" #include "ui_widget.h" #include "tgeneratenum.h" #include "tbubblesort.h" #include "tquicksort.h" #include <QDebug> #include <QThreadPool>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);qDebug() << "主线程:" << QThread::currentThread();/******************** 多线程的使用方法一 ****************/TGenerateNum *gen = new TGenerateNum; // 继承QThread类/******************* 多线程的使用方法二 **********************/QThread *bubbleThread = new QThread;TBubbleSort *bubble = new TBubbleSort;bubble->moveToThread(bubbleThread);/******************* 多线程的使用方法三 线程池的使用 **********************/TQuickSort *quicksort = new TQuickSort;QThreadPool::globalInstance()->setMaxThreadCount(10);// 按钮的信号槽connect(ui->btnStart, &QPushButton::clicked, this, [=](){gen->setCnt(10000);gen->start();});// 生成随机数connect(gen, &TGenerateNum::sendList, this, [=](QVector<int> list){quicksort->setList(list);QThreadPool::globalInstance()->start(quicksort);bubbleThread->start(); // 开启冒泡排序线程for(int i = 0; i < list.size(); i++){ui->listWidgetGenerate->addItem(QString::number(list[i]));}});connect(gen, &TGenerateNum::sendList, bubble, &TBubbleSort::working);connect(bubble, &TBubbleSort::sendList, this, [=](QVector<int> list){for(int i = 0; i < list.size(); i++){ui->listWidgetBubbleSort->addItem(QString::number(list[i]));}});connect(quicksort, &TQuickSort::sendList, this, [=](QVector<int> list){for(int i = 0; i < list.size(); i++){ui->listWidgetQuickSort->addItem(QString::number(list[i]));}});// 释放内存connect(this, &Widget::destroyed, this, [=](){gen->quit();gen->wait();gen->deleteLater();bubbleThread->quit();bubbleThread->wait();bubbleThread->deleteLater();bubble->deleteLater();}); }Widget::~Widget() {delete ui; }
生成随机数:
tgeneratenum.h
#ifndef TGENERATENUM_H #define TGENERATENUM_H#include <QObject> #include <QThread>class TGenerateNum : public QThread {Q_OBJECT public:TGenerateNum(QObject *parent=nullptr);void setCnt(qint32 cnt);// QThread interface protected:void run() override; signals:void sendList(QVector<int> list);private:qint32 m_cnt; }; #endif // TGENERATENUM_Htgeneratenum.cpp
#include "tgeneratenum.h" #include <QRandomGenerator> #include <QVector> #include <QElapsedTimer> #include <QDebug>TGenerateNum::TGenerateNum(QObject *parent):QThread(parent) {}void TGenerateNum::setCnt(qint32 cnt) {m_cnt = cnt; }void TGenerateNum::run() {qDebug() << "生成随机数线程地址:" << QThread::currentThread();QElapsedTimer time;time.start();QVector<int> list;for(int i = 0; i < m_cnt; i++){int num = QRandomGenerator::global()->bounded(100000);list.push_back(num);}int milsec = time.elapsed();qDebug() << "生成" << m_cnt << "个随机数总共用时:" << milsec << "毫秒";emit sendList(list); }生成随机数,需要加时间种子
冒泡排序:
tbubblesort.h
#ifndef TBUBBLESORT_H #define TBUBBLESORT_H#include <QObject>class TBubbleSort : public QObject {Q_OBJECT public:explicit TBubbleSort(QObject *parent = nullptr);void working(QVector<int> list); signals:void sendList(QVector<int> list); private:void bubbleSort(QVector<int>& list);QVector<int> m_list; };#endif // TBUBBLESORT_Htbubblesort.cpp
#include "tbubblesort.h" #include <QElapsedTimer> #include <QDebug> #include <QThread>TBubbleSort::TBubbleSort(QObject *parent): QObject{parent} {}void TBubbleSort::working(QVector<int> list) {qDebug() << "冒泡线程地址:" << QThread::currentThread();QElapsedTimer time;time.start();this->bubbleSort(list);int milsec = time.elapsed();qDebug() << "冒泡排序总共用时:" << milsec << "毫秒";emit sendList(list); }void TBubbleSort::bubbleSort(QVector<int> &list) {for (int i = 0; i < list.size(); i++){for (int j = 1; j < list.size()-i; j++){if (list[j - 1] > list[j]){int temp = list[j - 1];list[j - 1] = list[j];list[j] = temp;}}} }
快速排序:
tquicksort.h
#ifndef TQUICKSORT_H #define TQUICKSORT_H#include <QObject> #include <QRunnable>class TQuickSort : public QObject, public QRunnable {Q_OBJECT public:explicit TQuickSort(QObject *parent = nullptr);void setList(QVector<int> list); signals:void sendList(QVector<int> list);// QRunnable interface public:void run() override; private:void quick_sort(QVector<int>& list, int l, int r);QVector<int> m_list; };#endif // TQUICKSORT_Htquicksort.cpp
#include "tquicksort.h" #include <QElapsedTimer> #include <QDebug> #include <QThread> TQuickSort::TQuickSort(QObject *parent): QObject{parent}, QRunnable() {// 开启自动回收,由线程池回收对象资源setAutoDelete(true); }void TQuickSort::setList(QVector<int> list) {m_list = list; }void TQuickSort::run() {qDebug() << "快排线程地址:" << QThread::currentThread();QElapsedTimer time;time.start();this->quick_sort(m_list, 0, m_list.size());int milsec = time.elapsed();qDebug() << "快速排序总共用时:" << milsec << "毫秒";emit sendList(m_list); }void TQuickSort::quick_sort(QVector<int>& list, int l, int r){//如果小于等于1个数据元素·直接返回结束快排函数 r为数组元素总个数if(l+1 >= r){return ;}int first = l, last = r-1, key = list[first];while(first < last){while(first < last && list[last] >= key){--last;}//如果值小于 key分界值 交换list[first] = list[last];while(first < last && list[first] < key){++first;}//如果值大于key分界值 交换list[last] = list[first];}list[first] = key;//递归左右部分进行快排quick_sort(list, l, first);quick_sort(list, first+1, r); }
相关文章:
Qt的QThread、QRunnable和QThreadPool的使用
1.相关描述 随机生产1000个数字,然后进行冒泡排序与快速排序。随机生成类继承QThread类、冒泡排序使用moveToThread方法添加到一个线程中、快速排序类继承QRunnable类,添加到线程池中进行排序。 2.相关界面 3.相关代码 widget.cpp #include "widget…...
windows安装部署node.js并搭建Vue项目
一、官网下载安装包 官网地址:https://nodejs.org/zh-cn/download/ 二、安装程序 1、安装过程 如果有C/C编程的需求,勾选一下下图所示的部分,没有的话除了选择一下node.js安装路径,直接一路next 2、测试安装是否成功 【winR】…...
【计算机】本科考研还是就业?
其实现在很多计算机专业的学生考研,也是无奈的选择 技术发展日新月异,而在本科阶段,大家学着落后的技术,出来找工作自然会碰壁。而且现在用人单位的门槛越来越高,学历默认研究生起步,面试一般都是三轮起步…...
ChatGPT调教指南 | 咒语指南 | Prompts提示词教程(三)
在人工智能成为我们日常互动中无处不在的一部分的时代,与大型语言模型(llm)有效沟通的能力是无价的。“良好提示的26条原则”为优化与这些复杂系统的交互提供了全面的指导。本指南证明了人类和人工智能之间的微妙关系,强调清晰、专一和结构化的沟通方法。…...
小程序一键链接WIFI
1.小程序一键链接WIFI connectWifi: function() {var that this;//检测手机型号wx.getSystemInfo({success: function(res) {var system ;if (res.platform android) system parseInt(res.system.substr(8));if (res.platform ios) system parseInt(res.system.substr(4…...
结构体位域保存传感器数据
1、原理图分析: 8个74HC4052共用两个选通引脚,8个输入引脚,一共可以检测64个数字红外传感器。74HC4052的功能表如下,nY0表示所有Y0引脚。 S1 S0 Channel on 0 0 nY0 0 1 nY1 1 0 nY2 1 1 nY3 enum sensor_id{HS01 0, HS02, HS03, HS0…...
66-ES6:var,let,const,函数的声明方式,函数参数,剩余函数,延展操作符
1.JavaScript语言的执行流程 编译阶段:构建执行函数;执行阶段:代码依次执行 2.代码块:{ } 3.变量声明方式var 有声明提升,允许重复声明,声明函数级作用域 访问:声明后访问都是正常的&…...
prime_series_level-1靶场详解
环境搭建 官网https://www.vulnhub.com/entry/prime-1,358/ 直接导入靶机 解题思路 arp-scan -l 确认靶机ip为192.168.236.136 也可以使用nmap扫网段 nmap -sn 192.168.236.0/24 使用nmap扫描靶机开放的端口 nmap -sS -T5 --min-rate 10000 192.168.236.136 -sC -p- …...
LeetCode刷题笔记之二叉树(三)
一、寻找特定节点 1. 404【左叶子之和】 题目: 给定二叉树的根节点 root ,返回所有左叶子之和。代码: class Solution {public int sumOfLeftLeaves(TreeNode root) {//左叶子不止是最左边的叶子,而是二叉树中每个节点的左叶子…...
IBM在闪存系统集成实时恶意软件I/O检测功能
IBM在其最新一代FlashCore Modules(FCMs)固件中集成了使用机器学习进行实时勒索软件和其他攻击检测的功能。这些FCMs是专用于IBM FlashSystem 5000和Storwize阵列的闪存驱动器,采用U.2外形尺寸及NVMe接口。现有的第三代FCMs分别提供4.8、9.6、…...
bpmn-js中实现xml数据转为json数据
开发bpmn-js建模器,希望将bpmn数据格式转为json数据格式更加清晰的展示数据层次,以结果为导向分析需求,实现功能的思路有两种方式: 通过bpmn-js转化为JS数据对象,然后通过JS中提供的JSON模块转换为json数据将xml解析成dom对象,通过dom对象转化为json格式数据三方库这里主…...
HUAWEI Programming Contest 2024(AtCoder Beginner Contest 342)(A,B,C,D,E,F,G)
看不懂的英文,题意很难理解,这场还是有点难度的。 C需要处理,D是不太明显的dijikstra,E是线段树优化dp,F是个不好想的线段树,主席树应该也能做。 我觉得讲的很好的宝藏up主->B站视频讲解。之后会比较忙…...
解决Docker镜像中CentOS 8仓库问题
前言: 在yum执行过程中,持续遇到与CentOS 8上的’appstream’仓库元数据检索相关的错误。具体错误消息为:“错误:下载’appstream’仓库元数据失败:无法准备内部镜像列表:镜像列表中没有URL。” 问题分析&…...
顶顶通呼叫中心中间件-如何使处于机器人话术中的通话手动转接到坐席分机上讲解(mod_cti基于FreeSWITCH)
顶顶通呼叫中心中间件使用httpapi实现电话转接操作过程讲解(mod_cti基于FreeSWITCH) 需要了解呼叫中心中间件可以点以下链接了解顶顶通小孙 1、使用httpapi接口转接 一、打开web版的ccadmin并且找到接口测试 打开web-ccadmin并且登录,登录完成之后点击运维调试-再…...
HarmonyOS—使用数据模型和连接器
Serverless低代码开发平台是一个可视化的平台, 打通了HarmonyOS云侧与端侧能力,能够轻松实现HMS Core、AGC Serverless能力调用。其中,数据模型和连接器是两大主要元素。开发者在使用DevEco Studio的低代码功能进行开发时,可以使用…...
基于MQTT协议实现微服务架构事件总线
一、场景描述 昨天在博客《客户端订阅服务端事件的实现方法》中提出了利用websocket、服务端EventEmitter和客户端mitt实现客户端订阅服务端事件,大大简化了客户端对服务端数据实时响应的逻辑。上述方案适用于单服务节点的情形。 对于由服务集群支撑的微服务架构&…...
免费的Git图形界面工具sourceTree介绍
阅读本文同时请参阅-----代码库管理工具Git介绍 sourceTree是一款免费的Git图形界面工具,它简化了Git的使用过程,使得开发者可以更加方便地下载代码、更新代码、提交代码和处理冲突。下面我将详细介绍如何使用sourceTree进行这些操作。 1.下载和…...
【Appium UI自动化】pytest运行常见错误解决办法
通过Appium工具录制代码在pycharm上运行报错: 错误一: 1.提示 setup() 方法运行 error failed 解决办法:未创建 init __ 方法,创建一个空的__init.py文件就解决了。 原因: 错误二: 2.运行代码ÿ…...
IDEA如何开启Dashboard
普通的面板 Run Dashboard面板 修改配置文件 找到项目的.idea文件夹 点击编辑workspace.xml文件 添加下方代码 <component name"RunDashboard"><option name"ruleStates"><list><RuleState><option name"name" valu…...
【论文复现】——一种新的鲁棒三维点云平面拟合方法
目录 一、算法原理1、论文概述2、参考文献二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的GPT爬虫。 一、算法原理 1、论文概述 针对三维点云中的异常值和粗差点对平面拟合精度产生的影响,文章提出一…...
别再硬编码了!用Elasticsearch的Terms lookup query实现动态搜索条件(附用户偏好推荐实战)
动态搜索的艺术:用Elasticsearch Terms lookup构建个性化推荐系统 每次打开购物APP,首页推荐总能精准命中你的喜好——这背后藏着怎样的技术魔法?想象一下,当用户A喜欢电子产品而用户B偏爱美妆时,如何让同一套代码自动…...
【产教融合,协同育人】Altium 出席第七届全国高校自动化类专业教学论坛
2026年4月10日至12日,第七届全国高校自动化类专业教学论坛在西安盛大启幕。作为合作伙伴,Altium 教育生态负责人宋斌出席了此次大会,与在场代表们共话自动化类专业高质量发展新路径、新形态与新实践。Altium 教育生态负责人宋斌进行主题演讲依…...
在Vivado里用Verilog驱动N25Q128 SPI Flash,我踩过的两个坑(STARTUPE2原语与IOBUF调试)
Vivado中驱动N25Q128 SPI Flash的两个实战陷阱:STARTUPE2与IOBUF深度解析 在Xilinx FPGA开发中,SPI Flash驱动看似简单,但当真正动手实现时,总会遇到一些"教科书不会告诉你"的坑。特别是当使用N25Q128这类高性能Flash时…...
FUXA工业可视化平台架构解析:7天构建企业级SCADA系统
FUXA工业可视化平台架构解析:7天构建企业级SCADA系统 【免费下载链接】FUXA Web-based Process Visualization (SCADA/HMI/Dashboard) software 项目地址: https://gitcode.com/gh_mirrors/fu/FUXA 在工业自动化数字化转型浪潮中,企业面临传统SCA…...
real-anime-z实战教程:为原创IP‘琉璃姬’生成全套视觉资产(头像/立绘/LOGO)
real-anime-z实战教程:为原创IP琉璃姬生成全套视觉资产(头像/立绘/LOGO) 1. 项目背景与工具介绍 1.1 为什么选择real-anime-z 为原创动漫角色"琉璃姬"打造全套视觉资产是许多创作者面临的挑战。传统方式需要雇佣画师,…...
别再被‘透传’忽悠了:用ESP8266和CC3200模块做IoT项目时,这些坑你得提前知道
别再被‘透传’忽悠了:用ESP8266和CC3200模块做IoT项目时,这些坑你得提前知道 在智能家居和小型传感器节点开发中,ESP8266和CC3200这类UART串口WiFi模块因其低成本、易用性备受青睐。许多开发者会被模块的"透传"模式吸引——只需简…...
终极5个驱动清理技巧:如何彻底解决Windows系统卡顿问题
终极5个驱动清理技巧:如何彻底解决Windows系统卡顿问题 【免费下载链接】DriverStoreExplorer Driver Store Explorer 项目地址: https://gitcode.com/gh_mirrors/dr/DriverStoreExplorer 您的Windows电脑是否变得越来越慢?系统盘空间莫名其妙地减…...
wan2.1-vae提示词工程实战:从模糊描述到专业级输出的10个优化技巧
wan2.1-vae提示词工程实战:从模糊描述到专业级输出的10个优化技巧 1. 理解wan2.1-vae的核心能力 wan2.1-vae是基于Qwen-Image-2512模型的AI图像生成平台,它能将你的文字描述转化为高质量的视觉作品。这个模型特别擅长处理人物肖像、场景构建和风格化图…...
OFA-large模型实战教程:Kubernetes Helm Chart一键部署方案
OFA-large模型实战教程:Kubernetes Helm Chart一键部署方案 1. 项目简介与核心价值 今天要跟大家分享一个特别实用的部署方案:如何用Kubernetes Helm Chart一键部署OFA-large视觉蕴含模型Web应用。 如果你正在寻找一个能智能判断图片和文字是否匹配的…...
0421晨间日记
- 关键词 - 上午- 吃饭- 从五台山到大同 - 下午- 云冈石窟- 石头要好雕刻,就意味着容易损毁- 国家要统治- 人生来就是苦的,让你接受是苦的- 地主因为信佛,得到了好处的,愿意捐钱修建- 大同古城墙- 这个建立起来确实很壮观- 但是高…...
