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 <ctime>
#include <iostream>
<p>int main() {
clock_t start = clock();</p><pre class='brush:php;toolbar:false;'>// 模拟一段计算
volatile long sum = 0;
for (long i = 0; i < 100000000L; ++i) {
sum += i;
}
clock_t end = clock();
double cpu_time = static_cast<double>(end - start) / CLOCKS_PER_SEC;
std::cout << "CPU time: " << cpu_time << " s\n";
return 0;}
立即学习“C++免费学习笔记(深入)”;
关键点:
- 用
volatile防止编译器优化掉循环(否则clock()可能测到 0) - 必须用
static_cast<double>,不能写(double)(end - start) / CLOCKS_PER_SEC(C 风格转换易出错) -
CLOCKS_PER_SEC是宏,不是常量,不能取地址或用于模板非类型参数
更可靠的替代方案:std::chrono::high_resolution_clock
若需测量真实经过时间(wall-clock time),比如接口响应、文件读写、网络请求,应改用 std::chrono:
#include <chrono>
#include <iostream>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class='brush:php;toolbar:false;'>// 同样模拟计算
volatile long sum = 0;
for (long i = 0; i < 100000000L; ++i) {
sum += i;
}
auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(end - start);
std::cout << "Wall time: " << duration.count() << " μ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() 手动打点。











