linux下获取整体cpu使用率方法参看文章
linux下获取某个进程cpu使用率方法参考文章
linux top命令参考文章
题目
随心的控制cpu的使用率
电脑为4核
使用cat /proc/cpuinfo
查看cpu信息
方法一
使用while
和sleep()
来模拟空闲和忙碌的状态,达到控制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亲缘性参考文章