如何在c++中获取函数的执行时间 库的高精度计时【性能测试】

在C++中推荐用std::chrono::steady_clock获取函数执行时间,精度达纳秒级且跨平台稳定;需用duration_cast转换为毫秒等单位,并建议多次运行取中位数以提升测量可靠性。

库的高精度计时【性能测试】">

在 C++ 中,用 库获取函数执行时间是最常用、最可靠的方式,精度可达纳秒级(取决于硬件和系统支持),且完全不依赖平台。

使用 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()
  • 微秒:std::chrono::duration_cast<:chrono::microseconds>(duration).count()
  • 毫秒(常用):std::chrono::duration_cast<:chrono::milliseconds>(duration).count()
  • 带小数的毫秒(更精确):std::chrono::duration(duration).count()

封装成通用计时工具函数

为避免重复写样板代码,可封装一个模板函数,自动执行并返回毫秒(double 类型):

template
double time_it(Func&& f, Args&&... args) {
    auto start = std::chrono::steady_clock::now();
    std::forward(f)(std::forward(args)...);
    auto end = std::chrono::steady_clock::now();
    return std::chrono::duration(end - start).count();
}

调用示例:double ms = time_it([]{ some_heavy_work(); }); time_it(func, arg1, arg2);

性能测试注意事项

单次测量易受干扰(缓存预热、上下文切换、CPU 频率波动等),真实性能分析应结合多次运行与统计:

  • 至少运行 10–100 次,取平均值或中位数(更抗异常值)
  • 首次运行常偏慢,建议先“预热”一次再正式计时
  • 关闭编译器优化(如 -O0)会失真;测试应开启合理优化(如 -O2
  • 避免在计时区域内做 I/O、内存分配、锁操作等外部依赖行为