C++如何计算程序运行时间?(代码示例)

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

std::chrono 是 C++11 起最推荐的方式,精度高、跨平台、类型安全,比老式的 clock()time() 更可靠。

用 high_resolution_clock 测毫秒级耗时

适合测量小段代码(如算法执行、函数调用)的精确耗时:

#include 
#include 

int main() { auto start = std::chrono::high_resolution_clock::now();

// 你要测的代码,比如一个简单循环
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(end - start);

std::cout << "耗时: " << duration.count() << " 毫秒\n";
return 0;

}

测微秒或纳秒,只需换 duration_cast

根据需要调整时间单位,不改变计时逻辑:

  • 微秒std::chrono::duration_cast<:chrono::microseconds>(end - start)
  • 纳秒std::chrono::duration_cast<:chrono::nanoseconds>(end - start)
  • 秒(带小数)std::chrono::duration(end - start).count()

避免常见坑

几个容易出错但很关键的细节:

  • 别用 clock() 测 wall-clock 时间——它返回的是 CPU 时间,多线程下不准,且单位是 CLOCKS_PER_SEC,非秒
  • 别在 Release 模式下测空循环或无副作用代码——编译器可能直接优化掉,结果为 0
  • 单次测量易受干扰,要测得准可跑多次取平均,或用 std::chrono::steady_clock(更稳定,不随系统时间调整)
  • 如果测整个程序启动到结束,main() 开头记 start,结尾记 end 即可,无需额外线程

基本上就这些。用 chrono 三行搞定,清晰又靠谱。