C++ 程序耗时统计

在编程过程中经常需要统计一个代码段的耗时,本文主要记录 C++ 常用的耗时统计方式。

系统存储时间常见的两种方式为:

  1. 存储从1970年到现在经过多少时间
  2. 使用结构体分别存储当前时间的年月日时分秒

主要记录 time_tstruct time_valchrono 统计时间的相关函数使用方法:

  • time_t

    • 说明:存储了从1970年到现在经过了多少,所以使用time_t的精度也就是级别

    • 类型: time_t 实际上就是long int 类型

    • 函数:

      double difftime(time_t time1, time_t time2)
      
    • 示例:

      #include <ctime>
      #include <iostream>
      void test_time_t(){
      	time_t start_time, end_time;
      	time(&start_time);
      	...
      	time(&end_time);
      	double cost_time = difftime(end_time, start_time);
      	std::cout << "run func cost " << cost_time << " seconds" << std::endl;
      }
      
  • struct timeval

    • 说明:存储了从1970年到现在经过了多少微妙,所以使用timeval的精度也就是微妙级别

    • 类型:

      struct timeval{
          long tv_sec; /*秒*/
          long tv_usec; /*微秒*/
      };
      
    • 函数:

      int gettimeofday(struct timeval *tv, struct timezone *tz);
      
    • 注意:gettimeofdaylinux 系统函数

    • 示例

      #include <sys/time.>
      #include <unistd.h>
      #include <iostream>
      void test_timeval(){
      	struct timeval start_time;
          struct timeval end_time;
      	gettimeofday(&start_time, NULL);
      	...
      	gettimeofday(&end_time,NULL);
      	float cost_time = (end_time.tv_sec - start_time.tv_sec)*1000
                          + (end_time.tv_usec - start_time.tv_usec)/1000;
      	std::cout << "run func cost " << cost_time << " ms" << std::endl;
      }
      
  • chrono

    • 说明:chronoc++ 11中的时间库,提供计时,时钟等功能

    • 示例

    	  #include <chrono>
    	  using namespace std;
    	  using std::chrono::high_resolution_clock;
    	  using std::chrono::milliseconds;
    	  
    	  int test_chrono(){
    	  	high_resolution_clock::time_point start_time = high_resolution_clock::now();
    	  		...
    	  	high_resolution_clock::time_point end_time = high_resolution_clock::now();
    	  	milliseconds time_interval = std::chrono::duration_cast<milliseconds>(end_time - start_time);
    	  	cout << "run func cost " << time_interval.count() << " ms" endl;
    	  }
    
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值