实验描述
Linux的程序运行优先级nice分为了-20~19共40个等级,其使用了完全公平调度算法(CFS)来进行调度,但公平并不意味着每个等级所分到的CPU时间一致,由此来探究nice和CPU运行时间的关系。本次实验共写了一个具有不同优先级的多线程(双线程)程序和一个内核模块来查看程序两个进程的分别CPU虚拟运行时间和实际运行时间。
实验程序
具有不同优先级的双线程程序
程序描述
此程序只是一个简单的多线程程序,用sched_setaffinity()来对进程优先级赋值,最后执行一个while()循环使其一直运行以便比较二者的CPU实际运行时间。
重难点解析
线程与CPU绑定
因为要比较出CPU对不同等级优先级的执行情况,故不能允许其多核执行,否则若是分别在两个核执行则影响实验数据的准确。
核心方法
int sched_setaffinity(pid_t pid, unsigned int cpusetsize, cpu_set_t *mask);
其中pid代表想要为其绑定CPU的进程的进程号,为0则是当前进程。cpu_set_t是一个记录CPU集合的结构。
cpu_set_t cpuSet;
CPU_ZERO(&a