C++中获取程序运行时间推荐使用chrono库,如high_resolution_clock或steady_clock测量毫秒或微秒级时间间隔,精度高且跨平台;传统clock()函数可测CPU时间但精度较低,适用于简单场景。

在C++中获取程序运行时间,常用的方法有多种,主要依赖于标准库中的时钟函数。下面介绍几种实用且跨平台的实现方式,帮助你准确测量代码段或整个程序的执行时间。
使用 chrono 高精度时钟(推荐)
C++11 引入了 chrono 库,提供了高精度、类型安全的时间操作接口,适合测量短时间间隔。
基本思路是记录起始时间和结束时间,然后计算差值。以下是一个测量某段代码运行毫秒数的例子:
示例代码:
#include #includeint main() {auto start = std::chrono::high_resolution_clock::now();
// 要测量的代码段for (int i = 0; i < 1000000; ++i) { // 模拟工作}auto end = std::chrono::high_resolution_clock::now();auto duration = std::chrono::duration_cast(end - start);std::cout << "运行时间:" << duration.count() << " 微秒n";return 0;
}
你可以将 microseconds 替换为 milliseconds 或 seconds 来获得不同单位的结果。
立即学习“C++免费学习笔记(深入)”;
使用 clock() 函数(传统方法)
来自 的 clock() 函数是较老但广泛支持的方式,返回程序占用的CPU时间。
注意:它测量的是CPU时间,不完全等同于“真实时间”,特别是在多线程或系统空闲时可能不准确。
示例代码:
#include #includeint main() {clock_t start = clock();
// 要执行的操作for (int i = 0; i < 1000000; ++i) { // 模拟计算}clock_t end = clock();double elapsed_time = double(end - start) / CLOCKS_PER_SEC;std::cout << "运行时间:" << elapsed_time << " 秒n";return 0;
}
这种方法简单,但在高精度需求下不如 chrono 精确。
测量实时时间(wall-clock time)
如果你关心的是用户感知的“经过时间”,即从开始到结束的现实世界时间,建议仍使用 chrono 的 high_resolution_clock,因为它通常提供最佳的实时精度。
也可以用 system_clock 获取带日期的时间点,但对性能测量意义不大。重点是用 steady_clock 或 high_resolution_clock 避免受到系统时间调整的影响。
例如,使用 steady_clock 的写法与 high_resolution_clock 类似:
auto start = std::chrono::steady_clock::now();// ...auto end = std::chrono::steady_clock::now();
steady_clock 保证时间不会回退,适合做间隔测量。
基本上就这些常用方法。日常开发中优先选择 chrono,尤其是 high_resolution_clock,精度高、可读性强、跨平台性好。clock() 可用于简单场景或兼容旧编译器。关键是根据需求选择合适的时钟类型和时间单位。
以上就是C++如何获取程序运行时间_C++ 程序运行时间获取方法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1478051.html
微信扫一扫
支付宝扫一扫