linux编程中,如果用到计时,可以用struct timeval获取系统时间。struct timeval的函数原型如下:
struct timeval {
__kernel_time_t tv_sec; /* seconds */
__kernel_suseconds_t tv_usec; /* microseconds */
};
比如,如果要计算某代码运行的时间,可以使用如下代码:
int main() {
struct timeval tv;
long long start_time, stop_time, delta_time;
gettimeofday(&
tv, NULL);
start_time=
tv.tv_usec;
// your code here
gettimeofday(&
tv, NULL);
stop_time =
tv.tv_usec;
delta_time = (stop_time - start_time +
1000000)%
1000000;
}
delta_time就是运行你的代码运行的时间,单位为毫秒。
值得注意的是,tv_usec的最大值是1000000,即1秒,记到1000000后,又会从0开始,所以这里加上1000000再对1000000取余,解决delta_time为负数的问题。
转载于:https://www.cnblogs.com/craftor/p/3811597.html