编程之美

BoP——1.1 controlCPU

2017-10-09  本文已影响0人  Myth52125

linux下获取整体cpu使用率方法参看文章
linux下获取某个进程cpu使用率方法参考文章
linux top命令参考文章

题目

随心的控制cpu的使用率

电脑为4核
使用cat /proc/cpuinfo查看cpu信息

image.png

方法一

使用whilesleep()来模拟空闲和忙碌的状态,达到控制cpu的目。
因为是4核,所以开两个线程,执行下面的循环,堵满两个线程。可以到达50%,3个线程可以到达75%

void *methodOne(void *)
{
    cout << "start !" << endl;
    while (true)
    {
    }
    cout << "endl !" << endl;
}

在window下但线程只想上述循环,cpu尽然是稳定在13%左右,不明白。
如果是单核,那么需要一个线程模拟出忙碌和空闲的状态,所以循环中还需要有一个循环模拟忙碌,一个sleep()模拟空闲。
忙碌状态:可以根据cpu频率算出来一秒执行的循环次数,然后让cpu一秒执行周循环次数/2次.
空闲状态:sleep()模拟,根据系统来设置毫秒数。

方法二

方法一,首先与实际的硬件,相关联,换一个cpu需要重新计算。
如果要做到50%使用率,那么我们只需要让计算机忙碌10ms,再运行10ms,如此循环即可。
我么你可以使用sleep(10)去“空闲”10ms。
然后使用gettimeofday()获取经过的毫秒数,包装以后,来循环。
伪代码如下

int64_t passMircosecond(tm *oldtime,tm *newtime)
{
//使用gettimeofday()获取当前时间,和之前时间做差,获得经过的时间。
//返回经过的时间,并且填充新的newtime
}

//while 循环改为
tm t;
tm n;
gettimofday(&t);
int busytime = 10;
while(true)
{
  while(passMircosecond(t,n) < busytime)
  {
  }
  sleep(busytime);
  t=n;
}

方法三

方法二,只能是固定的cpu占用数值。而且会受到其他进程的影响。

如果我们根据系统当前的使用情况,同时我们不断的改变busytime,那么就可以获得随心所欲的cpu使用率。
当系统使用率过低的时候,我们去让他忙碌,过高的话,没办法啊,我们降不下来。

如果要适应运行环境,那么需要实时的获取cpu使用率,和其他信息,然后计算出忙碌状态和sleep的持续时间。
linux下没有直接获取cpu使用率的函数或者系统调用之类的。只有top可以获取整个cpu的使用率,因此需要system()函数,而该函数不能返回输出的内容,只能现实在shell上,因此需要一个将system()执行命令直接重定向到一个文件,然后在去读取文件内容。
top -n 1 |grep Cpu | cut -d "," -f 1 | cut -d ":" -f 2:获取cpuus
top -n 1 |grep Cpu | cut -d "," -f 2:获取cpusy
因此,

system("op -n 1 |grep Cpu | cut -d \",\" -f 1 | cut -d \":\" -f 2 >cpu.txt");

然后再去打开 cpu.txt,读取数据,然后作为当前cpu的使用率。

如果在多核机器上,我们可以将该进程绑定到一个固定的核心上,使该核心的cpu使用率曲线呈现我们想要的状态,这就需要cpu亲缘性参考文章

上一篇下一篇

猜你喜欢

热点阅读