在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; }
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)