clock用于获取程序运行的 CPU 时间。它返回自程序启动以来的 CPU 时钟滴答数,通常用于计算程序的执行时间。
1.头文件
#include <time.h>
2.函数原型
clock_t clock(void);
3.参数
无。
4.返回值
成功: 返回自程序启动以来经过的 CPU 时钟滴答数(clock_t 类型)。该返回值表示从程序启动到当前时间点所消耗的 CPU 时间。
失败: 如果出现错误,返回 CLOCKS_PER_SEC 的常量值 -1,并且 errno 被设置为 EINVAL。
clock_t 类型:clock_t 是一个整数类型,通常是 long 或 long long。
CLOCKS_PER_SEC:CLOCKS_PER_SEC 是一个常量,表示每秒钟的时钟滴答数。通常,它的值为 1000000(即每秒有 100 万个时钟滴答)。该常量通常用于将 clock() 返回的滴答数转换为秒。
5.示例:(使用clock函数获取程序启动到结束时间)
| #include <stdio.h>
#include <time.h> int main() { clock_t start, end; double cpu_time_used; // 记录程序开始时的时钟滴答数 start = clock(); // 模拟一些计算 for (volatile long i = 0; i < 100000000; i++); // 记录程序结束时的时钟滴答数 end = clock(); // 计算程序的 CPU 时间,并转换为秒 cpu_time_used = ((double)(end - start)) / CLOCKS_PER_SEC; printf("The program used %f seconds of CPU time.n", cpu_time_used); return 0; } |
6.自行编译并测试
| The program used 0.033987 seconds of CPU time. |
359