美文网首页编程之美
BoP——1.1 controlCPU

BoP——1.1 controlCPU

作者: Myth52125 | 来源:发表于2017-10-09 23:00 被阅读0次

    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亲缘性参考文章

    相关文章

      网友评论

        本文标题:BoP——1.1 controlCPU

        本文链接:https://www.haomeiwen.com/subject/yxrpyxtx.html