clock()测量CPU时间而非真实流逝时间,仅统计进程占用CPU的时间,sleep、I/O等待等不计入;需用double转换差值除以CLOCKS_PER_SEC,且存在溢出与跨平台精度问题,推荐用std::chrono替代。

clock() 测量的是 CPU 时间,不是真实流逝时间
clock() 返回自程序启动以来的处理器时钟滴答数(CLOCKS_PER_SEC 滴答为 1 秒),它统计的是当前进程实际占用 CPU 的时间。这意味着:如果程序在 sleep()、等待 I/O 或被系统调度挂起,这部分时间**不会计入** clock() 结果。
常见误用场景:
- 想测“用户等了多久”,却用了
clock()→ 实际得到的是后台计算耗时,远小于感知时长 - 多线程下只在主线程调用
clock()→ 无法反映所有线程总 CPU 消耗 - 跨平台时假设
CLOCKS_PER_SEC == 1000000→ Windows 下通常是 1000,Linux/macOS 通常是 1000000,不可硬编码
正确用法:用 double 除以 CLOCKS_PER_SEC 得秒数
必须把 clock() 差值转成 double 再除,否则整数除法会截断,尤其在耗时短时结果恒为 0。
include#include int main() { clock_t start = clock();
// 模拟一段计算 volatile long sum = 0; for (long i = 0; i zuojiankuohaophpcn 100000000L; ++i) { sum += i; } clock_t end = clock(); double cpu_time = static_castzuojiankuohaophpcndoubleyoujiankuohaophpcn(end - start) / CLOCKS_PER_SEC; std::cout zuojiankuohaophpcnzuojiankuohaophpcn "CPU time: " zuojiankuohaophpcnzuojiankuohaophpcn cpu_time zuojiankuohaophpcnzuojiankuohaophpcn " s\n"; return 0;}
立即学习“C++免费学习笔记(深入)”;
关键点:
- 用
volatile防止编译器优化掉循环(否则clock()可能测到 0)- 必须用
static_cast,不能写(double)(end - start) / CLOCKS_PER_SEC(C 风格转换易出错)CLOCKS_PER_SEC是宏,不是常量,不能取地址或用于模板非类型参数更可靠的替代方案:std::chrono::high_resolution_clock
若需测量真实经过时间(wall-clock time),比如接口响应、文件读写、网络请求,应改用
std::chrono:#include#include int main() { auto start = std::chrono::high_resolution_clock::now();
// 同样模拟计算 volatile long sum = 0; for (long i = 0; i zuojiankuohaophpcn 100000000L; ++i) { sum += i; } auto end = std::chrono::high_resolution_clock::now(); auto duration = std::chrono::duration_castzuojiankuohaophpcnstd::chrono::microsecondsyoujiankuohaophpcn(end - start); std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Wall time: " zuojiankuohaophpcnzuojiankuohaophpcn duration.count() zuojiankuohaophpcnzuojiankuohaophpcn " μs\n"; return 0;}
立即学习“C++免费学习笔记(深入)”;
优势:
- 返回真实流逝时间,含 sleep、I/O 等全部停顿
- 精度通常达纳秒级(取决于系统),比
clock()更稳定- 类型安全,支持自动单位转换(
milliseconds、nanoseconds)- 无平台差异陷阱,C++11 起标准保证可用
clock() 的最大陷阱:溢出与精度不足
clock_t通常是 32 位有符号整型。按CLOCKS_PER_SEC = 1000000算,约 2147 秒(35 分钟)后就会溢出回负值,导致差值为巨大负数,除出来是负时间。避免方式:
- 单次测量不要超过几分钟;长期监控请用
std::chrono::steady_clock- 不依赖
clock()做性能基线对比——不同机器上CLOCKS_PER_SEC不同,数值不可比- Windows 下
clock()精度极低(~15ms),短于该值的测量基本无效真正需要 CPU 时间分析时,优先考虑专用工具(如
perf、Visual Studio Profiler),而不是靠clock()手动打点。











