文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux下通过gettimeofday函数获取程序段执行时间【推荐】

2022-06-04 22:28

关注

在linux下计算某个程序段执行的时间一般使用gettimeofday函数,此函数的声明在sys/time.h文件中。此函数接收两个结构体参数,分别为timeval、timezone.

        两个结构体的声明如下:


struct timeval { 
  time_t tv_sec;  
  long tv_usec;   
}; 
struct timezone { 
  int tz_minuteswest; 
  int tz_dsttime; 
}; 

        一般通过gettimeofday函数获得当前时间时,第二个参数为nullptr。结构体timeval中的tv_sec表示秒,tv_usec表示微秒。

        matlab中通过tic(start a stopwatch timer)和toc(read the stopwatch timer)两个函数来给出程序段所运行的时间,这里通过两个宏TIC和TOC来实现。测试代码如下:


#include <sys/time.h> 
#include <unistd.h> 
#include <iostream> 
#define TIC                               \ 
  struct timeval time1, time2;                    \ 
  gettimeofday(&time1, nullptr); 
#define TOC                               \ 
  gettimeofday(&time2, nullptr);                   \ 
  double elapsed_time = (time2.tv_sec - time1.tv_sec) * 1000. +    \ 
        (time2.tv_usec - time1.tv_usec) / 1000.;        \ 
  fprintf(stdout, "Elapsed time: %lf(ms)\n", elapsed_time); 
int main() 
{ 
  unsigned int tm{10}; 
  TIC 
  for (int i = 0; i < 1000; ++i) { 
    usleep(tm); 
EONBdxGLF  } 
  TOC 
  return 0; 
} 

        执行结果如下:

&nbsp;   &nbsp;   执行过程:将终端定位到Linux_Code_Test/Samples_cplusplus目录下,执行:./build.sh,然后进入到build目录下,执行生成的执行文件即可。

        github: https://github.com/fengbingchun/Linux_Code_Test

总结

以上所述是小编给大家介绍的Linux下通过gettimeofday函数获取程序EONBdxGLF段执行时间,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯