在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 类型):
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~