一.概述
程序执行时间打印是优化程序的的重要手段,本文为用c接口实现打印时间的三种方法。本文程序均在qt5.12环境测试验证。
二.测试代码
1.方法一
使用 time() 测量秒数
#include <stdio.h>
#include <time.h>
int main() {
// 获取操作前的当前时间
time_t start_time = time(NULL);
// 执行一些操作(例如,一个简单的循环)
for (long i = 0; i < 1000000000; ++i);
// 获取操作后的当前时间
time_t end_time = time(NULL);
// 计算时间差
double duration = difftime(end_time, start_time);
// 打印时间差
printf("time: %.2f s\n", duration);
return 0;
}
测试结果:time: 1 s
2.方法二
使用 clock() 测量更高精度的时间
#include <stdio.h>
#include <time.h>
int main() {
// 获取操作前的当前时钟时间
clock_t start_time = clock();
// 执行一些操作(例如,一个简单的循环)
for (long i = 0; i < 1000000000; ++i);
// 获取操作后的当前时钟时间
clock_t end_time = clock();
// 计算时间差
double duration = (double)(end_time - start_time) / CLOCKS_PER_SEC;
// 打印时间差
printf("time: %.6f s\n", duration);
return 0;
}
测试结果:time: 1.251000 s
3.方法三
CLOCKS_PER_SEC是标准c的time.h头函数中宏定义的一个常数,表示一秒钟内CPU运行的时钟周期数,用于将clock()函数的结果转化为以秒为单位的量,但是这个量的具体值是与操作系统相关的使用 gettimeofday() 测量微秒级的时间#include <stdio.h>
#include <sys/time.h>
int main() {
struct timeval start, end;
// 获取操作前的当前时间
gettimeofday(&start, NULL);
// 执行一些操作(例如,一个简单的循环)
for (long i = 0; i < 1000000000; ++i);
// 获取操作后的当前时间
gettimeofday(&end, NULL);
// 计算时间差
double duration = (end.tv_sec - start.tv_sec) + (end.tv_usec - start.tv_usec) / 1e6;
// 打印时间差
printf("time: %.6f s\n", duration);
return 0;
}
测试结果:time: 1.254910 s
注意事项:
time(): 返回的秒数是整数,精确到秒,因此精度较低。
clock(): 提供的时间可能更精确,因为它是基于CPU时间,可以精确到毫秒。
gettimeofday(): 提供更高的时间精度,通常可以精确到微秒级。实际的时间输出将根据系统性能和执行时间而有所不同。