CPU亲合力就是指在Linux系统中能够将一个或多个进程绑定到一个或多个处理器上运行.
一个进程的CPU亲合力掩码决定了该进程将在哪个或哪几个CPU上运行.在一个多处理器系统中,设置CPU亲合力的掩码可能会获得更好的性能.
一个CPU的亲合力掩码用一个cpu_set_t结构体来表示一个CPU集合,下面的几个宏分别对这个掩码集进行操作:
·CPU_ZERO() 清空一个集合
·CPU_SET()与CPU_CLR()分别对将一个给定的CPU号加到一个集合或者从一个集合中去掉.
·CPU_ISSET()检查一个CPU号是否在这个集合中.

下面两个函数就是用来设置获取线程CPU亲和力状态: 
    ·sched_setaffinity(pid_t
pid, unsigned int cpusetsize, cpu_set_t *mask) 
      该函数设置进程为pid的这个进程,让它运行在mask所设定的CPU上.如果pid的值为0,则表示指定的是当前进程,使当前进程运行在mask所设定的那些CPU上.第二个参数cpusetsize是mask所指定的数的长度.通常设定为sizeof(cpu_set_t).如果当前pid所指定的进程此时没有运行在mask所指定的任意一个CPU上,则该指定的进程会从其它CPU上迁移到mask的指定的一个CPU上运行. 
    ·sched_getaffinity(pid_t
pid, unsigned int cpusetsize, cpu_set_t *mask) 
      该函数获得pid所指示的进程的CPU位掩码,并将该掩码返回到mask所指向的结构中.即获得指定pid当前可以运行在哪些CPU上.同样,如果pid的值为0.也表示的是当前进程

  1. cpu_set_t的定义
  2. # define __CPU_SETSIZE 1024
  3. # define __NCPUBITS (8 * sizeof (__cpu_mask))
  4. typedef unsigned long int __cpu_mask;
  5. # define __CPUELT(cpu) ((cpu) / __NCPUBITS)
  6. # define __CPUMASK(cpu) ((__cpu_mask) 1 << ((cpu) % __NCPUBITS))
  7. typedef struct
  8. {
  9. __cpu_mask __bits[__CPU_SETSIZE / __NCPUBITS];
  10. } cpu_set_t;
  11. # define __CPU_ZERO(cpusetp) \
  12. do { \
  13. unsigned int __i; \
  14. cpu_set_t *__arr = (cpusetp); \
  15. for (__i = 0; __i < sizeof (cpu_set_t) / sizeof (__cpu_mask); ++__i) \
  16. __arr->__bits[__i] = 0; \
  17. } while (0)
  18. # define __CPU_SET(cpu, cpusetp) \
  19. ((cpusetp)->__bits[__CPUELT (cpu)] |= __CPUMASK (cpu))
  20. # define __CPU_CLR(cpu, cpusetp) \
  21. ((cpusetp)->__bits[__CPUELT (cpu)] &= ~__CPUMASK (cpu))
  22. # define __CPU_ISSET(cpu, cpusetp) \
  23. (((cpusetp)->__bits[__CPUELT (cpu)] & __CPUMASK (cpu)) != 0)

测试代码:

[cpp] view plain copy

  1. #include<stdlib.h>
  2. #include<stdio.h>
  3. #include<sys/types.h>
  4. #include<sys/sysinfo.h>
  5. #include<unistd.h>
  6. #define __USE_GNU
  7. #include<sched.h>
  8. #include<ctype.h>
  9. #include<string.h>
  10. #include<pthread.h>
  11. #define THREAD_MAX_NUM 100  //1个CPU内的最多进程数
  12. int num=0;  //cpu中核数
  13. void* threadFun(void* arg)  //arg  传递线程标号(自己定义)
  14. {
  15. cpu_set_t mask;  //CPU核的集合
  16. cpu_set_t get;   //获取在集合中的CPU
  17. int *a = (int *)arg;
  18. printf("the a is:%d\n",*a);  //显示是第几个线程
  19. CPU_ZERO(&mask);    //置空
  20. CPU_SET(*a,&mask);   //设置亲和力值
  21. if (sched_setaffinity(0, sizeof(mask), &mask) == -1)//设置线程CPU亲和力
  22. {
  23. printf("warning: could not set CPU affinity, continuing...\n");
  24. }
  25. while (1)
  26. {
  27. CPU_ZERO(&get);
  28. if (sched_getaffinity(0, sizeof(get), &get) == -1)//获取线程CPU亲和力
  29. {
  30. printf("warning: cound not get thread affinity, continuing...\n");
  31. }
  32. int i;
  33. for (i = 0; i < num; i++)
  34. {
  35. if (CPU_ISSET(i, &get))//判断线程与哪个CPU有亲和力
  36. {
  37. printf("this thread %d is running processor : %d\n", i,i);
  38. }
  39. }
  40. }
  41. return NULL;
  42. }
  43. int main(int argc, char* argv[])
  44. {
  45. num = sysconf(_SC_NPROCESSORS_CONF);  //获取核数
  46. pthread_t thread[THREAD_MAX_NUM];
  47. printf("system has %i processor(s). \n", num);
  48. int tid[THREAD_MAX_NUM];
  49. int i;
  50. for(i=0;i<num;i++)
  51. {
  52. tid[i] = i;  //每个线程必须有个tid[i]
  53. pthread_create(&thread[0],NULL,threadFun,(void*)&tid[i]);
  54. }
  55. for(i=0; i< num; i++)
  56. {
  57. pthread_join(thread[i],NULL);//等待所有的线程结束,线程为死循环所以CTRL+C结束
  58. }
  59. return 0;
  60. }

编译命令:gcc bind.c -o bind -lpthread

执行:./bind

输出结果:略

特别注意:

#define __USE_GNU不要写成#define _USE_GNU

#include<pthread.h>必须写在#define __USE_GNU之后,否则编译会报错

查看你的线程情况可以在执行时在另一个窗口使用top -H来查看线程的情况,查看各个核上的情况请使用top命令然后按数字“1”来查看。

原文:https://blog.csdn.net/lanyzh0909/article/details/50404664

线程绑定CPU核-sched_setaffinity的更多相关文章

  1. Ubuntu系统进程绑定CPU核

    Ubuntu系统进程绑定CPU核 作者:chszs.版权全部,未经允许,不得转载. 博主主页:http://blog.csdn.net/chszs 本文讲述如何在Ubuntu系统中,把指定的进程绑定到 ...

  2. Linux编程之《进程/线程绑定CPU》

    Intro----- 通常我们在编写服务器代码时,可以通过将当前进程绑定到固定的CPU核心或者线程绑定到固定的CPU核心来提高系统调度程序的效率来提高程序执行的效率,下面将完整代码贴上. /***** ...

  3. taskset -pc PID 查看线程占用cpu核

    taskset -pc  PID 可以用于 查看 当前线程 对应绑定的 在 哪个核上面. 这个 可以用于 程序优化, 查看 哪个线程占用的 cpu 比重比较高 首先 可以通过  top  -H   - ...

  4. linux线程绑定cpu

    函数介绍 #define __USE_GNU #include <sched.h> void CPU_ZERO(cpu_set_t *set); void CPU_SET(int cpu, ...

  5. 为线程绑定CPU

    // learn gcc atomic variable #define _GNU_SOURCE #include <stdio.h> #include <stdlib.h> ...

  6. 线程绑定cpu

    #include <stdio.h> #include <pthread.h> #include <sys/sysinfo.h> #include <unis ...

  7. Windows10 临时将线程绑定至指定CPU的方法

    本文首发:https://www.somata.work/2019/WindowsThreadBind.html 将线程绑定至指定CPU,这个应该时很多管理员需要了解认知的操作了吧,这样可以在一定程度 ...

  8. NGINX源代码剖析 之 CPU绑定(CPU亲和性)

    作者:邹祁峰 邮箱:Qifeng.zou.job@gmail.com 博客:http://blog.csdn.net/qifengzou 日期:2014.06.12 18:44 转载请注明来自&quo ...

  9. linux下将不同线程绑定到不同core和cpu上——pthread_setaffinity_np

    =============================================================== linux下的单进程多线程的程序,要实现每个线程平均分配到多核cpu,主 ...

随机推荐

  1. 在linux oracle 10g/11g x64bit环境中,goldengate随os启动而自己主动启动的脚本

    在linux.oracle 10g/11g x64bit环境中,goldengate随os启动而自己主动启动的脚本 背景描写叙述: goldengate安装于/u01/ggs文件夹下 rhel5.5 ...

  2. Linux视频培训教程

    很详尽的Linux培训教程,既包含日常工作常常要用到的实践及技巧,又包含Linux认证及系统管理及架构,讲的很不错.最关键的.这么具体,完整的教程还是免费的.花了点时间拿它整理了下. 第一部分: Li ...

  3. Atitit.ati&#160;dwr的原理and设计&#160;attilax&#160;总结&#160;java&#160;php&#160;版本号

    Atitit.ati dwr的原理and设计 attilax 总结 java php 版本号 1. dwr的长处相对于ajax来说.. 1 2. DWR工作原理 1 3. Dwr的架构 2 4. 自己 ...

  4. python for android : BeautifulSoup 有 bug

    BeautifulSoup 善于网页数据分析 .可是 python for android : BeautifulSoup 有 bug , text = h4.a.text 仅仅能取得 None,因此 ...

  5. 35:字符串单词倒排 ReverseWords

    题目描述:对字符串中的所有单词进行倒排. 说明: 1.每个单词是以26个大写或小写英文字母构成: 2.非构成单词的字符均视为单词间隔符: 3.要求倒排后的单词间隔符以一个空格表示:如果原字符串中相邻单 ...

  6. 一起学android之怎样设置TextView中不同字段的字体颜色(22)

    在这里先看看效果图: OK,有时候,在我们的项目中会要求TextView中文本有一部分的字体颜色不一样.这时我们应该使用 SpannableStringBuilder这个工具类,当然这个类的功能非常强 ...

  7. Spring Data JPA 事务锁

    1.概述 在本快速教程中,我们将讨论在Spring Data JPA中为自定义查询方法和预定义存储库的CRUD方法启用事务锁, 我们还将查看不同的锁类型并设置事务锁超时. 2.锁类型 JPA定义了两种 ...

  8. 安装 r 里的 igraph 报错

    转载来源:http://genek.tv/article/40 1186 0 0 安装 r 里的 igraph 报错: foreign-graphml.c: In function ‘igraph_w ...

  9. jdbc 模板 连接

    package itcast; import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;i ...

  10. PowerBuilder -- 保存图片

    String ls_path, ls_file_name, ls_filter, ls_errInt li_ret, li_loop, li_i, li_file, li_bytesLong ll_f ...