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

QT并发机制

QT 提供了多种并发编程机制,使得开发者能够充分利用多核处理器优势,同时保持代码的可维护性和跨平台特性。以下是 QT 主要的并发机制:

1. QThread - 线程基础类

QThread 是 QT 中最基础的线程类,提供了创建和管理线程的能力。

class WorkerThread : public QThread {void run() override {// 在这里执行耗时操作qDebug() << "Worker thread running";}
};// 使用
WorkerThread *thread = new WorkerThread;
thread->start(); // 启动线程

2. 基于 QObject 的线程模型

更推荐的方式是将 QObject 移动到线程中:

class Worker : public QObject {Q_OBJECT
public slots:void doWork() {// 执行耗时任务emit resultReady(result);}
signals:void resultReady(const QString &result);
};// 使用
QThread *thread = new QThread;
Worker *worker = new Worker;
worker->moveToThread(thread);connect(thread, &QThread::started, worker, &Worker::doWork);
connect(worker, &Worker::resultReady, [](const QString &result){// 处理结果
});thread->start();

3. QtConcurrent - 高级并发API

QtConcurrent 提供了更高层次的并发编程接口:

// 并行映射
QList<int> list = {1, 2, 3, 4, 5};
QFuture<void> future = QtConcurrent::map(list, [](int &x){x *= 2;
});
future.waitForFinished(); // 等待完成// 并行过滤
QFuture<int> filtered = QtConcurrent::filtered(list, [](int x){return x > 5;
});// 并行归约
int sum = QtConcurrent::blockingReduced(list, [](int &result, int x){result += x;
});

4. QThreadPool 和 QRunnable

对于任务队列模式:

class Task : public QRunnable {void run() override {// 执行任务}
};// 使用
Task *task = new Task;
QThreadPool::globalInstance()->start(task);

5. 线程同步机制

QT 提供了多种线程同步工具:

  • QMutex - 互斥锁

    QMutex mutex;
    mutex.lock();
    // 临界区代码
    mutex.unlock();// 或使用 QMutexLocker
    QMutexLocker locker(&mutex);
    // 临界区代码
  • QReadWriteLock - 读写锁

    cpp

    QReadWriteLock lock;
    lock.lockForRead();  // 多个读取
    lock.lockForWrite(); // 单个写入
  • QSemaphore - 信号量

    QSemaphore sem(5); // 5个资源
    sem.acquire(3);    // 获取3个
    sem.release(2);    // 释放2个
  • QWaitCondition - 条件变量

    QWaitCondition condition;
    QMutex mutex;// 等待线程
    mutex.lock();
    condition.wait(&mutex);
    mutex.unlock();// 唤醒线程
    condition.wakeOne(); // 或 wakeAll()

6. 线程间通信

  • 信号槽机制:QT 的自动连接方式默认是队列连接(Qt::QueuedConnection),可以安全地跨线程通信

  • QMetaObject::invokeMethod:跨线程调用方法

    QMetaObject::invokeMethod(object, "methodName",Qt::QueuedConnection,Q_ARG(QString, "param"));

7. 异步操作

  • QFuture 和 QFutureWatcher 用于监控异步操作

    QFuture<int> future = QtConcurrent::run([](){return 42;
    });QFutureWatcher<int> *watcher = new QFutureWatcher<int>;
    connect(watcher, &QFutureWatcher<int>::finished, [](){qDebug() << "Done";
    });
    watcher->setFuture(future);

最佳实践

  1. 避免直接继承 QThread,推荐使用 moveToThread

  2. 主线程只用于 GUI 操作,耗时操作放在工作线程

  3. 使用信号槽进行线程间通信,避免直接共享数据

  4. 使用 QMutexLocker 等 RAII 类管理锁资源

  5. 考虑使用 QtConcurrent 简化并行算法实现

http://www.xdnf.cn/news/1083979.html

相关文章:

  • 数学建模的一般步骤
  • 暑假复习篇之五子棋③【人机对战篇1】
  • Oracle使用SQL一次性向表中插入多行数据
  • 数据可视化中常用的图表类型 及其适用场景,涵盖基础到高级,帮助你根据数据类型和展示目标选择合适的图表:
  • 【论文笔记】【强化微调】Pixel Reasoner:早期 tool call 的调用
  • react当中的this指向
  • 【从0-1的CSS】第3篇:盒子模型与弹性布局
  • 《前端路由重构:解锁多语言交互的底层逻辑》
  • 3. lvgl 9.3 vscode 模拟环境搭建 lv_port_pc_vscode-release-v9.3
  • Paimon索引概述
  • vue3.4中的v-model的用法~
  • 支持向量机(SVM)在肝脏CT/MRI图像分类(肝癌检测)中的应用及实现
  • 从源码到思想:OneCode框架模块化设计如何解决前端大型应用痛点
  • Application的onLowMemory从Android API 34开始系统不再触发,从API 35开始废弃
  • 【BTC】协议(共识机制)
  • 自定义指令
  • java+vue+SpringBoo职业生涯规划系统(程序+数据库+报告+部署教程+答辩指导)
  • 【AI大模型】Spring AI 基于mysql实现对话持久存储详解
  • 多模态大语言模型arxiv论文略读(149)
  • 【网络协议安全】任务13:ACL访问控制列表
  • 深度学习图像分类数据集—蘑菇可食性识别分类
  • 使用Python将PDF转换成word、PPT
  • 量子计算机技术(第二节,到底什么是量子)
  • 【CSS-15】深入理解CSS transition-duration:掌握过渡动画的时长控制
  • 高速信号眼图
  • ASP.NET代码审计 Web Forms框架 SQL注入漏洞
  • 【Python】使用读取到的文件
  • 零成本搭建浏览器远程Linux桌面:Ubuntu/Debian方案全解析
  • MySQL数据库主从复制
  • python-if结构、三目运算符