std::chrono是C++11起最推荐的计时方式,精度高、跨平台、类型安全;用high_resolution_clock测毫秒级耗时适合小段代码,可依需转微秒、纳秒或带小数的秒,注意避免clock()误用、编译器优化及单次测量干扰。

用 std::chrono 是 C++11 起最推荐的方式,精度高、跨平台、类型安全,比老式的 clock() 或 time() 更可靠。
用 high_resolution_clock 测毫秒级耗时
适合测量小段代码(如算法执行、函数调用)的精确耗时:
#include <iostream>
#include <chrono>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class="brush:php;toolbar:false;">// 你要测的代码,比如一个简单循环
volatile int sum = 0; // volatile 防止被编译器优化掉
for (int i = 0; i < 1000000; ++i) {
sum += i;
}
auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);
std::cout << "耗时: " << duration.count() << " 毫秒\n";
return 0;}
测微秒或纳秒,只需换 duration_cast
根据需要调整时间单位,不改变计时逻辑:
-
微秒:
std::chrono::duration_cast<:chrono::microseconds>(end - start)</:chrono::microseconds> -
纳秒:
std::chrono::duration_cast<:chrono::nanoseconds>(end - start)</:chrono::nanoseconds> -
秒(带小数):
std::chrono::duration<double>(end - start).count()</double>
避免常见坑
几个容易出错但很关键的细节:
立即学习“C++免费学习笔记(深入)”;
- 别用
clock()测 wall-clock 时间——它返回的是 CPU 时间,多线程下不准,且单位是CLOCKS_PER_SEC,非秒 - 别在 Release 模式下测空循环或无副作用代码——编译器可能直接优化掉,结果为 0
- 单次测量易受干扰,要测得准可跑多次取平均,或用
std::chrono::steady_clock(更稳定,不随系统时间调整) - 如果测整个程序启动到结束,
main()开头记 start,结尾记 end 即可,无需额外线程
基本上就这些。用 chrono 三行搞定,清晰又靠谱。










