Linux C语言之计算程序段运行时间
2016-03-08 11:56
465 查看
开发过程中有时候需要统计函数执行某项任务的耗时,可以利用头文件sys/time.h中提供的库函数来完成,
实现过程参考代码:
#include<stdio.h>
#include<sys/time.h>
void func(void){
int i = 0,j = 0;
for(;i < 10000;i++)
for(;j < 10000;j++);
}
int main(int argc,char **argv){
struct timeval start;
struct timeval end;
float timer;
gettimeofday(&start,NULL); //结构体start当前时间(1970年1月1日到现在的时间)
func();
gettimeofday(&end,NULL);
timer = end.tv_sec - start.tv_sec + (float)(end.tv_usec - start.tv_usec)/1000000; //计算start和end之间的时间差
printf("timer = %fs\n",timer);
return 0;
}
运行结果:
timer = 0.000038s
实现过程参考代码:
#include<stdio.h>
#include<sys/time.h>
void func(void){
int i = 0,j = 0;
for(;i < 10000;i++)
for(;j < 10000;j++);
}
int main(int argc,char **argv){
struct timeval start;
struct timeval end;
float timer;
gettimeofday(&start,NULL); //结构体start当前时间(1970年1月1日到现在的时间)
func();
gettimeofday(&end,NULL);
timer = end.tv_sec - start.tv_sec + (float)(end.tv_usec - start.tv_usec)/1000000; //计算start和end之间的时间差
printf("timer = %fs\n",timer);
return 0;
}
运行结果:
timer = 0.000038s
相关文章推荐
- Linux socket 初步
- Linux Kernel 4.0 RC5 发布!
- linux lsof详解
- linux 文件权限
- Linux 执行数学运算
- 10 篇对初学者和专家都有用的 Linux 命令教程
- 如何组织构建多文件 C 语言程序(二)
- Linux 与 Windows 对UNICODE 的处理方式
- Ubuntu12.04下QQ完美走起啊!走起啊!有木有啊!
- 解決Linux下Android开发真机调试设备不被识别问题
- 运维入门
- 运维提升
- Linux 自检和 SystemTap
- Ubuntu Linux使用体验
- c语言实现hashmap(转载)
- Linux 信号signal处理机制
- linux下mysql添加用户
- Scientific Linux 5.5 图形安装教程