推荐使用std::chrono::steady_clock进行高精度计时,因其单调递增且不受系统时间调整影响,配合duration_cast可精确转换微秒、毫秒等单位,并可通过封装Timer类实现便捷复用,避免system_clock导致的计时误差。

在C++中,std::chrono 是一个用于处理时间的现代化库,自 C++11 起引入,非常适合做高精度计时。相比传统的 clock() 或 gettimeofday(),它更简洁、类型安全且跨平台。
获取高精度时钟
std::chrono 提供了三种主要时钟:
- std::chrono::system_clock:系统时间,可被调整,不适合精确测量。
- std::chrono::steady_clock:单调递增时钟,不受系统时间调整影响,推荐用于计时。
-
std::chrono::high_resolution_clock:最高精度时钟,通常就是
steady_clock的别名。
建议使用 std::chrono::steady_clock 来避免因系统时间跳变导致的问题。
基本用法:测量代码执行时间
下面是一个使用 steady_clock 测量函数或代码段运行时间的示例:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <chrono>
<p>int main() {
// 记录开始时间
auto start = std::chrono::steady_clock::now();</p><pre class='brush:php;toolbar:false;'>// 模拟耗时操作
for (int i = 0; i < 1000000; ++i) {
// 做一些工作
}
// 记录结束时间
auto end = std::chrono::steady_clock::now();
// 计算耗时(微秒)
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(end - start);
std::cout << "耗时: " << duration.count() << " 微秒\n";
return 0;}
支持多种时间单位
你可以将结果转换为不同单位,例如:
-
std::chrono::nanoseconds:纳秒 -
std::chrono::microseconds:微秒 -
std::chrono::milliseconds:毫秒 -
std::chrono::seconds:秒
比如要得到毫秒数:
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(end - start); std::cout << "耗时: " << ms.count() << " 毫秒\n";
如果想获得浮点形式的秒数(保留小数):
auto seconds = std::chrono::duration<double>(end - start); std::cout << "耗时: " << seconds.count() << " 秒\n";
封装成可复用的计时器类
为了方便多次测量,可以封装一个简单的计时器:
#include <chrono>
#include <iostream>
<p>class Timer {
public:
Timer() { reset(); }</p><pre class='brush:php;toolbar:false;'>void reset() {
m_start = std::chrono::steady_clock::now();
}
int64_t elapsed_microseconds() const {
return std::chrono::duration_cast<std::chrono::microseconds>(
std::chrono::steady_clock::now() - m_start
).count();
}
int64_t elapsed_milliseconds() const {
return std::chrono::duration_cast<std::chrono::milliseconds>(
std::chrono::steady_clock::now() - m_start
).count();
}private: std::chrono::steady_clock::time_point m_start; };
使用方式:
Timer timer; // ... 执行任务 std::cout << "用时: " << timer.elapsed_microseconds() << " 微秒\n";
基本上就这些。只要记住优先使用 steady_clock,配合 duration_cast 转换单位,就能实现稳定、高精度的计时。不复杂但容易忽略细节,比如误用 system_clock 可能导致计时不准确。











