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

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

如何在c++中获取函数的执行时间 库的高精度计时【性能测试】-第1张图片-佛山资讯网

在 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++ 性能测试

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~