使用std::chrono::steady_clock进行稳定计时,因不受系统时间调整影响,适合精确测量时间段,结合now()获取时间点,计算时间差。

在C++中,chrono库是进行高精度计时的推荐方式。它位于标准库头文件<chrono>中,结合std::chrono::high_resolution_clock或std::chrono::steady_clock可以实现精确的时间测量。下面介绍几种常用且准确的计时方法。
std::chrono::steady_clock 是最常用的计时钟,因为它保证时间不会被系统调整影响(如NTP校正),适合测量时间段。
基本用法如下:
#include <chrono><br>
#include <iostream><br><br>
auto start = std::chrono::steady_clock::now();<br>
// 执行需要计时的操作<br>
for (int i = 0; i < 1000000; ++i) {<br>
// 模拟工作<br>
}<br>
auto end = std::chrono::steady_clock::now();<br><br>
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(end - start);<br>
std::cout << "耗时: " << duration.count() << " 微秒" << std::endl;
通过 duration_cast 可以将时间差转换为不同单位,例如:
立即学习“C++免费学习笔记(深入)”;
std::chrono::nanoseconds:纳秒std::chrono::microseconds:微秒std::chrono::milliseconds:毫秒std::chrono::seconds:秒根据实际需求选择合适的精度。例如,短时间操作建议使用微秒或纳秒。
为了方便多次使用,可以封装一个简单的计时器类:
class Timer {<br>
public:<br>
Timer() { start = std::chrono::steady_clock::now(); }<br><br>
void reset() {<br>
start = std::chrono::steady_clock::now();<br>
}<br><br>
template <typename T = std::chrono::microseconds><br>
long long elapsed() const {<br>
return std::chrono::duration_cast<T>(<br>
std::chrono::steady_clock::now() - start).count();<br>
}<br><br>
private:<br>
std::chrono::steady_clock::time_point start;<br>
};<br><br>
// 使用示例:<br>
Timer t;<br>
// 做一些事<br>
std::cout << "用时: " << t.elapsed() << " 微秒" << std::endl;
避免使用 std::chrono::system_clock 来测量时间间隔,因为它的值可能因系统时间调整而跳变,不适合做性能分析。
如果需要更高可读性,可以用 std::format(C++20)或流输出格式化时间。
基本上就这些。只要用对时钟类型和单位,chrono库能提供足够精确的计时能力。不复杂但容易忽略的是选择steady_clock而非system_clock。正确使用后,无论是测函数运行时间还是性能调优都更加可靠。
以上就是C++如何使用chrono库精确计时_C++ chrono精确计时方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号