把线程放到指定CPU中运行

前言

当前计算机都是多核的,linux2.6提供了进程绑定cpu功能,将进程指定到某个core上执行,方便管理进程。
linux提供了sysconf系统调用可以获取系统的cpu个数和可用的cpu个数。

使用方法

//目前在线的CPU数量
int cpu_nums = sysconf(_SC_NPROCESSORS_ONLN) 

/// @brief 把线程放到指定CPU中运行
/// @param [in] cpu_index CPU序号,从0开始,0代表第一个CPU
void sys_thread_set_cpu(unsigned int cpu_index)
{
    cpu_set_t mask;

    CPU_ZERO(&mask);
    CPU_SET(cpu_index, &mask);

    int tid = sys_get_tid();
    if (-1 == sched_setaffinity(tid, sizeof(mask), &mask))
    {
        printf("%s:%s:%d, WARNING: Could not set thread to CPU %d\n", __FUNCTION__, __FILE__, __LINE__, cpu_index);
    }
}

/// @brief 获取线程tid
int sys_get_tid()
{
    int tid = 0;
    tid = syscall(__NR_gettid);
    return tid;
}

应用场景举例

将UI线程限制在一个CPU,将其他实时性要求较高的线程限制在另一个CPU。
这样,当UI需要占用大量CPU时间时,就不会拖累其他实时性要求较高的线程的执行。
同样可以将UI线程与一些优先级不高但耗时的异步运算线程设置在不同CPU上,避免UI给人卡顿的感觉。

你可能感兴趣的:(C/C++,Linux)