qt+Linux+arm多核CPU 亲和性

复制代码
#include <QCoreApplication>
#include <QThread>
#include <pthread.h>
#include <sched.h>
#include <iostream>

void setThreadAffinity(int coreId) {
    cpu_set_t cpuset;
    CPU_ZERO(&cpuset);
    CPU_SET(coreId, &cpuset);// 设置线程执行在cpu编号为cpu的核上

    // 获取当前线程ID
    pthread_t thread = pthread_self();
    // 设置当前线程的亲和性
    int result = pthread_setaffinity_np(thread, sizeof(cpu_set_t), &cpuset);
    if (result != 0) {
        qWarning() << "Failed to set thread affinity, error code:" << result;
    } else {
        qDebug() << "Thread successfully bound to CPU" << cpu;
    }
}

class WorkerThread : public QThread {
public:
    void run() override {
        setThreadAffinity(1);  // 绑定到 CPU 核心 1
        std::cout << "Thread is running on core 1" << std::endl;
        // 模拟一些工作
        for (int i = 0; i < 1000000; ++i);
    }
};

int main(int argc, char *argv[]) {
    QCoreApplication a(argc, argv);

    WorkerThread worker;
    worker.start();

    return a.exec();
}

目前大部分的CPU都支持多核,QT的主线程默认运行在第一个CPU的核心中,当执行复杂而耗时的任务是,程序界面有可能会出现卡顿,而其它的核心又没用到,白白浪费了资源。

qt的QThead类本身是没有设置cpu亲和性的接口的,需要自己封装一个接口将QT线程运行到指定的cpu核心中。

前提是要确定cpu是支持多核的

相关推荐
lifewange13 小时前
Linux 服务管理故障排查小手册
linux·运维·服务器
LUCIFER13 小时前
[驱动之路(九)——UART(串口)子系统]学习总结,万字长篇,一文彻底搞懂UART(串口)子系统(含串口数据收发流程解析)
linux·驱动开发
忙里偷闲学python13 小时前
ceph介绍和安装
linux·ceph·kubernetes
zhong_kh14 小时前
字符串判断
linux·运维·服务器
来鸟 鸣间14 小时前
i2c_add_driver关键流程
linux·i2c
fengyue011014 小时前
C++使用epoll实现高并发tcp服务
linux·服务器·网络·c++
谷雨不太卷14 小时前
Linux_文件指令
linux·运维·服务器
0vvv014 小时前
Vimer
linux·靶机
MediaTea14 小时前
Python:实例 __dict__ 详解
java·linux·前端·数据库·python
jerryinwuhan15 小时前
linux_shell_2
linux