在c++中推荐用std::chrono::steady_clock获取函数执行时间,精度达纳秒级且跨平台稳定;需用duration_cast转换为毫秒等单位,并建议多次运行取中位数以提升测量可靠性。
性能测试】">
在 C++ 中,用 <chrono></chrono> 库获取函数执行时间是最常用、最可靠的方式,精度可达纳秒级(取决于硬件和系统支持),且完全不依赖平台。
使用 steady_clock 进行稳定计时
std::chrono::steady_clock 是推荐的计时器,它单调递增、不受系统时间调整影响,适合测量耗时。避免使用 system_clock(可能因 NTP 同步跳变)或 high_resolution_clock(在某些标准实现中只是别名,行为不统一)。
- 记录开始时间:
auto start = std::chrono::steady_clock::now(); - 执行目标函数:
your_function(); - 记录结束时间:
auto end = std::chrono::steady_clock::now(); - 计算差值:
auto duration = end - start;
将时间差转换为可读单位
duration 是一个模板类型,需显式转换为具体单位(如毫秒、微秒)。推荐用 duration_cast,它会自动做截断或舍入(默认向零截断):
- 纳秒:
std::chrono::duration_cast<:chrono::nanoseconds>(duration).count()</:chrono::nanoseconds> - 微秒:
std::chrono::duration_cast<:chrono::microseconds>(duration).count()</:chrono::microseconds> - 毫秒(常用):
std::chrono::duration_cast<:chrono::milliseconds>(duration).count()</:chrono::milliseconds> - 带小数的毫秒(更精确):
std::chrono::duration<double std::milli>(duration).count()</double>
封装成通用计时工具函数
为避免重复写样板代码,可封装一个模板函数,自动执行并返回毫秒(double 类型):
立即学习“C++免费学习笔记(深入)”;
template<typename Func, typename... Args>
double time_it(Func&& f, Args&&... args) {
auto start = std::chrono::steady_clock::now();
std::forward<Func>(f)(std::forward<Args>(args)...);
auto end = std::chrono::steady_clock::now();
return std::chrono::duration<double, std::milli>(end - start).count();
}调用示例:double ms = time_it([]{ some_heavy_work(); }); 或 time_it(func, arg1, arg2);
性能测试注意事项
单次测量易受干扰(缓存预热、上下文切换、CPU 频率波动等),真实性能分析应结合多次运行与统计:
- 至少运行 10–100 次,取平均值或中位数(更抗异常值)
- 首次运行常偏慢,建议先“预热”一次再正式计时
- 关闭编译器优化(如
-O0)会失真;测试应开启合理优化(如-O2) - 避免在计时区域内做 I/O、内存分配、锁操作等外部依赖行为











