在C++中推荐用std::chrono::steady_clock获取函数执行时间,精度达纳秒级且跨平台稳定;需用duration_cast转换为毫秒等单位,并建议多次运行取中位数以提升测量可靠性。
性能测试】">
在 C++ 中,用 <chrono></chrono> 库获取函数执行时间是最常用、最可靠的方式,精度可达纳秒级(取决于硬件和系统支持),且完全不依赖平台。
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 频率波动等),真实性能分析应结合多次运行与统计:
-O0)会失真;测试应开启合理优化(如 -O2)以上就是如何在c++++中获取函数的执行时间 库的高精度计时【性能测试】的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号