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;
    	  }
    
(1) 测试日期类成员函数,在主函数中列出菜单选项,可以完成日期的加减比较等测试功能。 (2) 完善程序功能,在日期相加的菜单选项中增加日期加天数,结果为新日期;日期家月份,结果为新日期,要考虑闰年情况。 (3) 完善程序功能,在日期相减的菜单选项中增加日期减天数,结果为新日期;日期减月份,结果为新日期,要考虑闰年情况。 (4) 显示日期时增加显示星期及英文形式的月份的功能。 (5) 增加输入的甄别功能,即输入非法数据(如负数、日期超过31天、时间超过24小时等情况)的识别显示功能。 (1) 仿照日期类编写时间类CTime_t,可以完成时间的设置、运算、比较等功能。 (2) 增加时间的输入功能,既可以选择输入格式,可以输入hh:mm:ss格式的信息。 (3) 增加时间的输出格式,可以输出12小时的时间格式。 (4) 编写时间和日期的派生类CDati,完成日期与时间的联合设置、运算、比较等功能,要求该派生类可以完成:日期时间加天数或时间等于新的日期时间,日期时间减天数或等于新的日期时间,两个日期时间相减等于天数或时间等工作,在程序中考虑闰年等具体情况,并重载各种运算符。 (5) 增加输入的甄别功能,即输入非法数据,即输入非法数据(如负数、日期超过31天、时间超过24小时等情况)的识别显示功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值