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

在C++中获取程序运行时间,常用的方法有多种,主要依赖于标准库中的时钟函数。下面介绍几种实用且跨平台的实现方式,帮助你准确测量代码段或整个程序的执行时间。
使用 chrono 高精度时钟(推荐)
C++11 引入了 chrono 库,提供了高精度、类型安全的时间操作接口,适合测量短时间间隔。
基本思路是记录起始时间和结束时间,然后计算差值。以下是一个测量某段代码运行毫秒数的例子:
示例代码:
美间AI:让设计更简单
45
查看详情
#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++免费学习笔记(深入)”;
使用 clock() 函数(传统方法)
来自 <ctime> 的 clock() 函数是较老但广泛支持的方式,返回程序占用的CPU时间。
注意:它测量的是CPU时间,不完全等同于“真实时间”,特别是在多线程或系统空闲时可能不准确。
示例代码:
美间AI:让设计更简单
45
查看详情
#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 精确。
测量实时时间(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() 可用于简单场景或兼容旧编译器。关键是根据需求选择合适的时钟类型和时间单位。
































暂无评论内容