>

测量检验usleep函数对CPU占用率的影响

- 编辑:正版管家婆马报彩图 -

测量检验usleep函数对CPU占用率的影响

[RK_2014_0918]linux下,测试usleep函数对CPU占用率的影响,rk_2014_0918usleep

一、本机环境

CPU信息
Intel(R) Core(TM) i3 CPU  M 350  @ 2.27GHz

Intel(R) Core(TM) i3 CPU  M 350  @ 2.27GHz

Intel(R) Core(TM) i3 CPU  M 350  @ 2.27GHz

Intel(R) Core(TM) i3 CPU  M 350  @ 2.27GHz

内存信息
MemTotal: 1990228 kB

 

二、搭建测试代码

1.测试代码

#include <iostream>
#include <unistd.h>

using namespace std;

#define ElapsedTime 1

int
main(void)
{
    cout << "current pid : " << getpid() << endl;

    while (1)
    {
        //usleep(ElapsedTime);
    }

    return 0;
}

2.编译

# g++ -o test_usleep.o test_usleep.cpp

3.运行

# ./test_usleep.o

 

三、CPU占用率

注:测试test_usleep.o时,不要运行其他程序。

1.没有"usleep(ElapsedTime);"这句代码

CPU占用率:99.9%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9540 root 20 0 3368 893 760 R 99.9 0.0 0:07.52 test_usleep.o 

2.#define ElapsedTime 1            // 1微秒

CPU占用率:99.9%
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9556 root 20 0 3368 872 760 R 99.9 0.0 0:05.10 test_usleep.o 

3.#define ElapsedTime 10          // 10微秒

CPU占用率:14.0%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9596 root 20 0 3368 868 760 R 14.0 0.0 0:09.99 test_usleep.o

4.#define ElapsedTime 100        // 100微秒

CPU占用率:11.7%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9610 root 20 0 3368 868 760 S 11.7 0.0 0:05.16 test_usleep.o 

5.#define ElapsedTime 1000      // 1000微秒=1毫秒

CPU占用率:1.7%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9624 root 20 0 3368 868 760 S 1.7 0.0 0:00.79 test_usleep.o

6.#define ElapsedTime 10000    // 10000微秒=10毫秒

CPU占用率:0.3%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9634 root 20 0 3368 868 760 S 0.3 0.0 0:00.04 test_usleep.o 

7.#define ElapsedTime 100000  // 100000微秒=100毫秒

CPU占用率:0.0%

PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 
9644 root 20 0 3368 872 760 S 0.0 0.0 0:00.00 test_usleep.o

 

四、参考信息

1.linux中,获取CPU信息

cat /proc/cpuinfo

2.linux中,获取内存信息

cat /proc/meminfo

3.linux中,使用top查看单个进程的状态信息

top -p pid

 

五、网址

  

 

【完结】

 

Sleep函数:

教一个Linux下使用Openmp的问题

linux下结果正常么?

可能是CPU占用的计算方法不一样。Windows CPU占用率计算有时候很怪异。特别你那里还有io,没把内核CPU占用算进去的话,0%的占用并不奇怪。  

功 能: 执行挂起一段时间  

linux中怎实现sleep(0)的功可以

linux下的sleep(0),有些时候被实现为下面这样:

unsigned int sleep (unsigned int seconds)
{
……
/* This is not necessary but some buggy programs depend on this. */
if (seconds == 0)
return 0;
……
}

如果你的程序对实时性要求不那么高,可以使用usleep(1),不然就只能用信号或者其他事件机制了。  

一、本机环境 CPU信息Intel(R) Core(TM) i3 CPU M 350 @ 2 .27GHz Intel(R) Core(TM) i3...

用 法: unsigned sleep(unsigned seconds);  

注意:  

在VC中使用带上头文件#include <windows.h>,在Linux下,gcc编译器中,使用的头文件因gcc版本的不同而不同#include <unistd.h> 

在VC中,Sleep中的第一个英文字符为大写的"S" ,在linux下不要大写,在标准C中是sleep, 不要大写,简单的说VC用Sleep, 别的一律使用sleep

在VC中,Sleep()里面的单位,是以毫秒为单位,所以如果想让函数滞留1秒的话,应该是Sleep(1000); 在Linux下,sleep()里面的单位是秒,而不是毫秒。

示例:

#include<stdio.h>
#include<windows.h>
int main()
{
    int a=100;
    Sleep(3000);// 滞停3s打印a
    printf("%d",a);
    return 0;
}

usleep函数:

功能: usleep功能把进程挂起一段时间, 单位是微秒us(百万分之一秒)。

语法: void usleep(int micro_seconds);

返回值: 无

注意:这个函数不能工作在 Windows 操作系统中。

usleep() 与sleep()类似,用于延迟挂起进程。进程被挂起放到reday queue。只是一般情况下,延迟时间数量级是秒的时候,尽可能使用sleep()函数。且此函数已被废除,可使用nanosleep。 

如果延迟时间为几十毫秒,或者更小,尽可能使用usleep()函数。这样才能最佳的利用CPU时间。

delay函数: 

功 能: 将程序的执行暂停一段时间,单位是毫秒ms(千分之一秒)  

用 法: void delay(unsigned milliseconds);  

示例:  

#include<dos.h>  

int main(void)  

{  

sound(440);  

delay(500);  

nosound();  

return 0;  

}

delay()是循环等待,该进程还在运行,占用处理器。

sleep()不同,它会被挂起,把处理器让给其他的进程。

本文由正版管家婆马报彩图发布,转载请注明来源:测量检验usleep函数对CPU占用率的影响