Linux下精确控制时间的函数
2013-07-10 11:51
417 查看
Linux下精确控制时间的函数
在测试程序接口运行时间的时候,常用time,gettimeofday等函数,但是这些函数在程序执行的时候是耗费时间的,如果仅仅测试时间还行,但是如果程序中用到时间控制类的函数,如time, gettimeofday自身还会消耗不少时间,且增加程序执行的成本,这样得到的时间不精确。针对这种情况,使用CPU心跳的函数来处理时间,经封装后的函数得到时间精确,且使用方便。
缺点:有一些机子由于硬件原因,可能不支持CPU心跳rdtscpll函数的使用,一般在虚拟机上都不行。
使用情况:在我做机顶盒测试工具的时候,使用该方法去控制每秒钟连接用户数(每秒钟连接100个用户),测试效果比较理想,基本是每隔1秒钟有100个用户上线。
下面贴上函数代码:
#include <stdio.h> #include <unistd.h> #include <sys/time.h> #include <asm/msr.h> long long g_var_llOneSecJiffiesCount = 0; long long GetCurCpuHopCount() { long long llcurrentcpuhopcount; int iaux; rdtscpll(llcurrentcpuhopcount,iaux); return llcurrentcpuhopcount; } int main(int argc, char* argv[]) { long long llstartvalue = 0; long long llendvalue = 0; struct timeval starttm,endtm; int iaux = 0; gettimeofday(&starttm,NULL); rdtscpll(llstartvalue,iaux); sleep(3); rdtscpll(llendvalue,iaux); gettimeofday(&endtm,NULL); g_var_llOneSecJiffiesCount = ((llendvalue-llstartvalue)*1000000/(endtm.tv_sec*1000000-starttm.tv_sec*1000000+endt m.tv_usec-starttm.tv_usec));//使用心跳来代替妙 long long begin_time = GetCurCpuHopCount(); sleep(100);//该处可以测试一些功能 long long end_time = GetCurCpuHopCount(); long long use_time = (end_time - begin_time) * 1000000 / g_var_llOneSecJiffiesCount; printf("测试一个功能 use time(us): %lld\n",use_time); return 0; }
执行结果:
测试一个功能 use time(us): 100,002,362
结论:由此可见,效果还是比较理想的。误差极小,可以忽略。
相关文章推荐
- Linux下精确控制时间的函数
- 浅析Linux下精确控制时间的函数
- Linux下精确控制时间的函数
- Linux系统下精确到微秒级的时间操作函数
- Linux常见文件系统操作命令、进程调用命令、进程控制C函数、时间函数
- Qt 使用Windows API 函数精确控制循环执行的周期时间
- Linux精确计时,及常用C时间函数(转)
- linux返回精确到毫秒的时间函数:gettimeofday
- Linux 获取精确时间函数
- Linux精确计时,及常用C时间函数
- Linux的时间函数
- linux 下的时间获取函数
- [转]Linux时间函数
- 控制linux动态链接库(so, standard object)导出函数
- [转]linux时间相关结构体和函数整理
- Linux时间函数之gettimeofday()函数之使用方法
- <Linux+Qt>时间控制事件触发
- linux下获取时间的函数
- Linux时间函数
- linux 下的时间获取函数