代码改变世界

linux/ubuntu下时间/time函数以及睡眠/sleep函数的使用

2012-12-06 09:44  小耳  阅读(1953)  评论(0编辑  收藏  举报
程序的计时在测试效率时是一个很重要的环节。
在vc下sleep函数表示睡眠的毫秒数,
在linux(ubuntu)下sleep函数有所不同,sleep(int n)中的参数n表示的是,想要更精确的要用usleep(int n),其中的n表示的是微秒数
我们还可以通过使用汇编语句rdtsc来取得cpu时钟周期来计时,可以达到纳秒级别的计时(不过实际上波动比较大)。

废话不多  usleep功能把进程挂起一段时间, 单位是微秒(百万分之一秒);
  头文件: unistd.h
  语法: void usleep(int micro_seconds);
  返回值: 无
  内容说明:本函数可暂时使程序停止执行。参数 micro_seconds 为要暂停的微秒数(us)。
  注意:这个函数不能工作在 Windows 操作系统中。参见:usleep() 与sleep()类似,用于延迟挂起进程。进程被挂起放到reday queue。
  只是一般情况下,延迟时间数量级是秒的时候,尽可能使用sleep()函数。且此函数已被废除,可使用nanosleep。如果延迟时间为几十毫秒(1ms = 1000us),或者更小,尽可能使用usleep()函数。这样才能最佳的利用CPU时间说。

 青春就应该这样绽放  游戏测试:三国时期谁是你最好的兄弟!!  你不得不信的星座秘密