首页 > 代码库 > linux 统计 程序 运行时间
linux 统计 程序 运行时间
测试 代码运行时间
linux 中的 <sys/time.h> 中 有个函数可以获取当前时间,精确到 微秒 ----> gettimeofday()
1 #include <sys/time.h> // int gettimeofday(struct timeval *tv, struct timezone *tz); 2 /********************************************* 3 * struct timeval 4 * { 5 * time_t tv_sec; // seconds 6 * suseconds_t tv_usec; // microseconds:微秒 10^(-6)s, 这里的 tv_sec 用的是 微秒 7 * // millisecond :毫秒 10^(-3)s 8 * } 9 ********************************************** 10 * struct timezone 11 * { 12 * int tz_minuteswest; // minutes west of Greenwich 13 * int tz_dsttime; // type of DST correction 14 * } 15 **********************************************/
使用时,定义两个 struct timeval 变量(通常 gettimeofday() 的第二个参数 设为 NULL),分别保存 代码测试 前后的时刻,最后相减,即可获取 代码运行时间 (可转换为自己需要的时间)。
1 #include <stdio.h> 2 #include <sys/time.h> // for gettimeofday() 3 #include <string.h> // for memset() 4 5 int main() 6 { 7 int i = 10000000; 8 struct timeval start, end; // define 2 struct timeval variables 9 10 //------------------------- 11 gettimeofday(&start, NULL); // get the beginning time 12 //------------------------- 13 14 // test code 15 while(i) 16 { 17 i--; 18 } 19 20 //------------------------- 21 gettimeofday(&end, NULL); // get the end time 22 //------------------------- 23 24 long long total_time = (end.tv_sec - start.tv_sec) * 1000000 + (end.tv_usec - start.tv_usec); // get the run time by microsecond 25 printf("total time is %lld us\n", total_time); 26 total_time /= 1000; // get the run time by millisecond 27 printf("total time is %lld ms\n", total_time); 28 }
测试结果:(CentOS 6.5, gcc 4.4.7)
total time is 49658 us
total time is 49 ms
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。