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

在C++中获取程序运行时间,常用的方法有多种,主要依赖于标准库中的时钟函数。下面介绍几种实用且跨平台的实现方式,帮助你准确测量代码段或整个程序的执行时间。
基本思路是记录起始时间和结束时间,然后计算差值。以下是一个测量某段代码运行毫秒数的例子:
示例代码:
#include <iostream>
#include <chrono>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">// 要测量的代码段
for (int i = 0; i < 1000000; ++i) {
// 模拟工作
}
auto end = std::chrono::high\_resolution\_clock::now();
auto duration = std::chrono::duration\_cast<std::chrono::microseconds>(end - start);
std::cout << "运行时间:" << duration.count() << " 微秒\n";
return 0;}
你可以将 microseconds 替换为 milliseconds 或 seconds 来获得不同单位的结果。
立即学习“C++免费学习笔记(深入)”;
注意:它测量的是CPU时间,不完全等同于“真实时间”,特别是在多线程或系统空闲时可能不准确。
示例代码:
#include <iostream>
#include <ctime>
<p>int main() {
clock_t start = clock();</p><pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">// 要执行的操作
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 精确。
也可以用 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++ 程序运行时间获取方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号