Linux C语言 高精度时间函数:gettimeofday() 获取时间差
程序员文章站
2024-01-23 14:51:58
...
- 简介:
为了获取某函数调用耗时.在C语言中可以使用函数gettimeofday()函数来得到时间。它的精度可以达到微秒, 且在x86-64平台gettimeofday()已不是系统调用,不会陷入内核, 多次调用不会有性能损失. - 函数原型:
#include<sys/time.h>
int gettimeofday(struct timeval*tv,struct timezone *tz ) -
说明:
<1>.gettimeofday()会把目前的时间用tv 结构体返回,当地时区的信息则放到tz所指的结构中
<2>.struct timeval结构体为时间变量, 包括两个成员变量:tv_sec(秒), tv_usec(微秒); 第二个结构体为时区, 本示例没有用到可以置为NULL.
struct timeval{
long tv_sec;/*秒*/
long tv_usec;/*微妙*/
};
struct timezone{
int tz_minuteswest;/*和Greewich时间差了多少分钟*/
int tz_dsttime;/*type of DST correction*/
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
代码示例:
struct timeval tvBegin, tvEnd;
gettimeofday(&tvBegin, NULL);
//耗时函数执行...
gettimeofday(&tvEnd, NULL);
//<1>.获得毫秒数:
double dDuration = 1000 * (tvEnd.tv_sec - tvBegin.tv_sec) + ((tvEnd.tv_usec - tvBegin.tv_usec) / 1000.0);
//<2>.获得秒数:
double dDuration = (tvEnd.tv_sec - tvBegin.tv_sec) + ((tvEnd.tv_usec - tvBegin.tv_usec) / 1000.0) / 1000.0;
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
注意: 获得秒数时, 分母需要为 1000.0, 如果是1000, 则返回整数,这样就不精确了.
原因:
相同数据类型的数据、变量进行运算,结果保持原有数据类型。
当不同数据类型的数据、变量进行运算时,结果为精度高的数据类型。
例如:1/2 的结果为0; 1.0/2 的结果为 0.5
C语言其它时间函数(Linux&Win)
上一篇: linux源码中的二分法:lib/bsearch.c
下一篇: linux下统计程序/函数运行时间
推荐阅读
-
linux下使用gettimeofday函数获取程序执行时间
-
Linux C语言 高精度时间函数:gettimeofday() 获取时间差
-
Linux下常用的时间函数,及windows c获取系统时间方法
-
linux常用的时间获取函数(time,gettimeofday,clock_gettime,_ftime,localtime,strftime )
-
Linux下通过gettimeofday函数获取程序段执行时间【推荐】
-
Linux C获取时间函数
-
linux C 下的时间函数localtime_r()、gettimeofday()、time()、ctime_r()等时间函数总结
-
C语言中的时间函数(Linux)
-
Linux下获取时间函数gettimeofday()