在C语言中设置计时可以使用多种方法,下面将介绍两种常用的方法:使用<time.h>
库和gettimeofday()
函数,以及使用<windows.h>
库和QueryPerformanceCounter()
函数。
1. 使用<time.h>
库和gettimeofday()
函数
步骤:
1、包含头文件 <time.h>
。
2、定义起始时间和终止时间的结构体变量。
3、使用gettimeofday()
函数获取起始时间。
4、执行需要计时的代码。
5、再次使用gettimeofday()
函数获取终止时间。
6、计算时间差并输出结果。
示例代码:
#include <stdio.h> #include <time.h> int main() { struct timeval start, end; long elapsed_time; // 获取起始时间 gettimeofday(&start, NULL); // 执行需要计时的代码 for (int i = 0; i < 1000000; i++) { // 模拟耗时操作 } // 获取终止时间 gettimeofday(&end, NULL); // 计算时间差并输出结果(单位:秒) elapsed_time = (end.tv_sec start.tv_sec) * 1000 + (end.tv_usec start.tv_usec) / 1000; printf("Elapsed time: %ld ms ", elapsed_time); return 0; }
2. 使用<windows.h>
库和QueryPerformanceCounter()
函数(仅适用于Windows平台)
步骤:
1、包含头文件 <windows.h>
。
2、定义起始时间和终止时间的变量。
3、使用QueryPerformanceCounter()
函数获取起始时间。
4、执行需要计时的代码。
5、再次使用QueryPerformanceCounter()
函数获取终止时间。
6、计算时间差并输出结果。
示例代码:
#include <stdio.h> #include <windows.h> int main() { LARGE_INTEGER frequency, start, end; double elapsed_time; // 获取系统时钟频率(每秒计数次数) QueryPerformanceFrequency(&frequency); QueryPerformanceCounter(&start); // 获取起始时间 // 执行需要计时的代码 for (int i = 0; i < 1000000; i++) { // 模拟耗时操作 } QueryPerformanceCounter(&end); // 获取终止时间 elapsed_time = (double)(end.QuadPart start.QuadPart) / frequency.QuadPart; // 计算时间差(单位:秒) printf("Elapsed time: %f seconds ", elapsed_time); return 0; }
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。