概述
前言
当前计算机都是多核的,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 %dn", __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给人卡顿的感觉。
最后
以上就是危机奇迹为你收集整理的把线程放到指定CPU中运行前言使用方法应用场景举例的全部内容,希望文章能够帮你解决把线程放到指定CPU中运行前言使用方法应用场景举例所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复