0

0

C++如何计算代码执行耗时_C++ 代码执行耗时计算方法

穿越時空

穿越時空

发布时间:2025-10-11 13:00:01

|

1112人浏览过

|

来源于php中文网

原创

使用 chrono 库可精确测量 C++ 代码执行时间:1. 在代码前后获取 high_resolution_clock 时间点;2. 计算差值并转为微秒等单位输出;3. 可封装 Timer 结构体复用。推荐此跨平台高精度方法,避免旧式 clock() 函数。

c++如何计算代码执行耗时_c++ 代码执行耗时计算方法

在C++中计算代码执行耗时,常用的方法是利用标准库中的 chrono 模块。它提供了高精度的时间测量功能,适合用于性能分析和代码优化。

使用 chrono 计算执行时间

chrono 是 C++11 引入的时间处理库,位于 std::chrono 命名空间下。通过记录代码段开始和结束的时刻,可以精确计算耗时。

基本步骤如下:

  • 在代码执行前获取当前时间点(std::chrono::high_resolution_clock::now()
  • 执行目标代码
  • 代码执行后再次获取当前时间点
  • 计算两个时间点之间的差值

示例代码:

立即学习C++免费学习笔记(深入)”;

#include 
#include 

int 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_castzuojiankuohaophpcnstd::chrono::microsecondsyoujiankuohaophpcn(end - start);

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "耗时: " zuojiankuohaophpcnzuojiankuohaophpcn duration.count() zuojiankuohaophpcnzuojiankuohaophpcn " 微秒" zuojiankuohaophpcnzuojiankuohaophpcn std::endl;

return 0;

}

选择合适的时间单位

根据实际耗时长短,可以选择不同的时间单位进行输出:

绘蛙AI修图
绘蛙AI修图

绘蛙平台AI修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

下载
  • 纳秒:std::chrono::nanoseconds
  • 微秒:std::chrono::microseconds
  • 毫秒:std::chrono::milliseconds
  • :std::chrono::seconds

例如,若预期耗时较长,可使用毫秒或秒;若为高性能关键路径,建议用微秒或纳秒以获得更精细的数据。

封装成可复用函数

为了方便多次测量,可以将计时逻辑封装成一个简单的结构体或函数对象:

struct Timer {
    std::chrono::time_point start;
Timer() { start = std::chrono::high_resolution_clock::now(); }

void reset() { start = std::chrono::high_resolution_clock::now(); }

long long elapsed_microseconds() {
    auto now = std::chrono::high_resolution_clock::now();
    return std::chrono::duration_castzuojiankuohaophpcnstd::chrono::microsecondsyoujiankuohaophpcn(now - start).count();
}

};

使用方式:

Timer t;
// 执行某些操作
std::cout << "耗时:" << t.elapsed_microseconds() << " 微秒\n";

基本上就这些。chrono 提供了跨平台、高精度且类型安全的计时方法,推荐在现代 C++ 项目中优先使用。注意避免使用过时的 clock() 函数,因为它精度较低且行为受平台影响较大。

相关专题

更多
golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

193

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

185

2025.07.04

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

28

2025.12.30

金山文档相关教程
金山文档相关教程

本专题整合了金山文档相关教程,阅读专题下面的文章了解更多详细操作。

29

2025.12.30

PS反选快捷键
PS反选快捷键

本专题整合了ps反选快捷键介绍,阅读下面的文章找到答案。

25

2025.12.30

表格中一行两行的方法
表格中一行两行的方法

本专题整合了表格中一行两行的相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.30

cpu温度过高解决方法大全
cpu温度过高解决方法大全

本专题整合了cpu温度过高相关教程,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

ASCII码介绍
ASCII码介绍

本专题整合了ASCII码相关内容,阅读专题下面的文章了解更多详细内容。

31

2025.12.30

GPS是什么
GPS是什么

本专题整合了GPS相关内容,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号