C++中推荐使用std::chrono库测量程序运行时间,通过high_resolution_clock::now()获取起始和结束时间点,利用duration_cast将时间差转换为毫秒、微秒或纳秒单位,精度高且跨平台;也可封装成Timer类方便复用,而传统clock()函数因精度低已不推荐使用。

在C++中计算程序运行时间,常用的方法是使用标准库中的 chrono 头文件。它提供了高精度的时钟和时间操作功能,适合测量代码段的执行耗时。下面介绍几种实用的方法。
这是C++11之后推荐的方式,精度高且跨平台支持良好。
基本步骤:
// 示例代码:测量一段代码的运行时间
#include <iostream>
#include <chrono>
using namespace std;
using namespace std::chrono;
立即学习“C++免费学习笔记(深入)”;
int main() {
// 记录开始时间
auto start = high_resolution_clock::now();
// 要测量的代码段
for (int i = 0; i < 1000000; ++i) {
// 模拟一些工作
}
// 记录结束时间
auto end = high_resolution_clock::now();
// 计算运行时间(毫秒)
auto duration = duration_cast<milliseconds>(end - start);
cout << "运行时间: " << duration.count() << " 毫秒" << endl;
return 0;
}
如果需要更高精度,可以将时间单位改为微秒(microseconds)或纳秒(nanoseconds)。
auto duration = duration_cast<microseconds>(end - start);换成 nanoseconds 可获得纳秒级精度,适用于极短操作的性能测试。
在C++早期版本中,常用 <ctime> 中的 clock() 函数。
#include <iostream> // 执行代码
for (int i = 0; i < 1000000; ++i);
clock_t end = clock();
double time_spent = (double)(end - start) / CLOCKS_PER_SEC;
cout << "运行时间: " << time_spent << " 秒" << endl;
return 0;
}
这种方法简单,但精度较低,且受系统时钟分辨率限制,不推荐用于高精度测量。
可以把计时逻辑封装成一个简单的类或函数,方便多次使用。
struct Timer { Timer() { start_time = std::chrono::high_resolution_clock::now(); }
void elapsed() {
auto end = std::chrono::high_resolution_clock::now();
auto ms = std::chrono::duration_cast<std::chrono::milliseconds>(end - start_time).count();
std::cout << "耗时: " << ms << " ms" << std::endl;
}
};
使用方式:
Timer t;基本上就这些。对于大多数情况,使用 std::chrono::high_resolution_clock 是最准确、最现代的选择。
以上就是c++++怎么计算程序运行时间_c++程序运行时间计算方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号