QT创建线程,QT多线程的创建和使用,QT线程池

一·、在Qt中创建多线程的原因和优势

1. **UI响应性:**
   - 在单线程模型中,如果需要执行长时间运行的任务(如网络请求、文件I/O、计算密集型操作等),这将会阻塞主线程,导致UI无响应。通过在单独的线程中执行这些任务,可以确保主线程保持响应性,提高用户体验。

2. **利用多核处理器:**
   - 多线程允许应用程序利用多核处理器的性能优势。通过并行执行任务,可以提高应用程序的性能和效率。

3. **任务分离:**
   - 将不同任务放在不同线程中可以更好地组织和管理代码,提高代码的可读性和维护性。

4. **避免阻塞:**
   - 在GUI应用程序中,使用多线程可以避免阻塞用户界面,保持程序的流畅性和响应性。

5. **并发性:**
   - 通过多线程可以实现并发处理,同时执行多个任务,提高系统的效率。

6. **异步操作:**
   - 多线程使得可以异步执行任务,比如在后台处理数据、下载文件等,在任务完成时通知主线程更新UI。

7. **减少资源冲突:**
   - 通过多线程可以降低资源竞争和冲突,避免因为多个任务同时访问资源而引起的问题。

总的来说,使用多线程可以提高应用程序的性能、响应性和并发处理能力,同时增强程序的可维护性和代码清晰度。在Qt中,通过提供丰富的多线程支持,开发者可以相对容易地实现多线程操作,并充分利用多核处理器的优势。

项目实现效果

二、多线程的创建方法(一)

通过创建多个继承与QThread的类来实现多线程的创建和使用。

本章内容实现三个子线程的创建和使用,分别实现(1)随机数的创建、(2)生成的随机数的快速排序、(3)生成的随机数的冒泡排序。同时将结果显示到主线程界面中。

一、新创建一个Class文件

这里选择QObject,因为QObject是QThread的基类

二、修改myThread的.h文件和.cpp文件

修改结果如下:

三、创建线程类对象

创建三个类对象,方便实现三个线程操作。

四、重写run方法

mythread.h文件如下:

#ifndef MYTHREAD_H
#define MYTHREAD_H

#include <QThread>
//获取随机数的类对象******************************************
class Random : public QThread
{
    Q_OBJECT
public:
    explicit Random(QObject *parent = nullptr);
protected:
    //重写run方法
    virtual void run();
signals:
    void sendRandom(QVector<int> list);//传递随机数数据的信号
    void sendRandTime(int);//发送耗时
public slots:
    void Random_num_handler(int num_t);//处理主程序传递过来的随机数
private:
    int num;//随机数个数
};

//冒泡排序类对象********************************************
class MaoSort : public QThread
{
    Q_OBJECT
public:
    explicit MaoSort(QObject *parent = nullptr);
protected:
    //重写run方法
    virtual void run();
signals:
    void sendMaoSort(QVector<int> list);//发送排序完成的数列到主程序
    void sendMaoTime(int);//发送耗时
public slots:
    void Random_num_handler(QVector<int> list);//处理主程序传递过来的随机数
private:
    QVector<int> list;//存储传递过来的数列
};

//快速排序类对象*************************************************
class QuickSort : public QThread
{
    Q_OBJECT
public:
    explicit QuickSort(QObject *parent = nullptr);
protected:
    //重写run方法
    virtual void run();
signals:
    void sendQuickSort(QVector<int> list);//发送排序完成的数列到主程序
    void sendQuiTime(int);//发送耗时
public slots:
    void Random_num_handler(QVector<int>);//处理主程序传递过来的随机数
    void quickSort(QVector<int> &list, int low, int high);
pri
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值