c++中如何计算程序运行时间_c++ clock函数测量耗时方法【实例】

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;

}

关键点:

  • 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;

}

优势:

  • 返回真实流逝时间,含 sleep、I/O 等全部停顿
  • 精度通常达纳秒级(取决于系统),比 clock() 更稳定
  • 类型安全,支持自动单位转换(millisecondsnanoseconds
  • 无平台差异陷阱,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() 手动打点。