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

结论:由此可见,效果还是比较理想的。误差极小,可以忽略。

最新文章

  1. Theano: CNMeM is disabled, CuDNN not available
  2. hdu acmsteps 2.1.3 Cake
  3. Linux-设置环境变量
  4. Codeforces Round #246 (Div. 2)——D题
  5. 由“大数据量Excel入库高效方式”瞥见“并联系统”之优势
  6. Java学习笔记之:Java的数据类型
  7. 读&lt;&lt;代码整洁之道&gt;&gt;的感想
  8. VS2010中使用CL快速 生成DLL的方法
  9. 为View设置左右切换动画
  10. tensorflow+ssd_mobilenet实现目标检测的训练
  11. 接口详解例子代码(附Java1.8的接口新特性)
  12. [Unity3D]降低向Shader中传值的开销
  13. 【Go命令教程】6. go doc 与 godoc
  14. Docker安装和常用命令
  15. mysql链接 显示 error: &#39;Access denied for user &#39;root&#39;@&#39;localhost&#39; (using password: NO)&#39;
  16. JS:事件委托
  17. crontab的用法
  18. Python之Web2py框架使用
  19. HDUOJ ---1423 Greatest Common Increasing Subsequence(LCS)
  20. api数据接口

热门文章

  1. 类CL_ABAP_TYPEDESCR,动态取得运行时类型
  2. 单元测试工具 SmokeTest
  3. JQuery和JSON方式参数传递并处理JAVAWEB中文乱码问题
  4. cocos2d-x游戏开发系列教程-搭建cocos2d-x的windows开发环境
  5. 怎样配置PHP环境和安装Zendstdio编辑器
  6. Ajax - 异步调用后台程序 -JSON
  7. iOS 5 故事板入门(3)
  8. Android应用开发学习笔记之绘图
  9. go iota
  10. Oracle12C 怎样导入scott用户