新闻中心

c++如何测量代码的执行时间_C++计算函数运行时长的几种方式

2025-11-17
浏览次数:
返回列表
C++中推荐使用chrono库测量函数执行时间,示例代码展示如何用high_resolution_clock获取微秒级精度,也可封装Timer类便于复用,传统clock()方法因依赖CPU时间而精度较低,专业场景可用Google Benchmark。

c++如何测量代码的执行时间_c++计算函数运行时长的几种方式

在C++开发中,测量代码或函数的执行时间对性能分析和优化非常重要。以下是几种常用且有效的方法来精确计算函数运行时长。

使用 chrono 高精度时钟(推荐)

C++11 引入了 chrono 库,提供了高精度、跨平台的时间测量功能,是目前最推荐的方式。

你可以使用 std::chrono::high_resolution_clocksteady_clock 来记录时间点,然后计算差值。

示例代码:

#include <iostream>
#include <chrono>
<p>void someFunction() {
// 模拟耗时操作
for (int i = 0; i < 1000000; ++i);
}</p><p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class="brush:php;toolbar:false;">someFunction();

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;

}

可以根据需要将单位改为 millisecondsnanoseconds 等。

使用 clock() 函数(传统方式)

来自 clock() 是较老但广泛支持的方法,它返回程序运行的“时钟滴答”数。

通过除以 CLOCKS_PER_SEC 转换为秒。

示例代码:

#include <iostream>
#include <ctime>
<p>int main() {
clock_t start = clock();</p><pre class="brush:php;toolbar:false;">// 执行目标函数
for (int i = 0; i < 1000000; ++i);

clock_t end = clock();
double elapsed = double(end - start) / CLOCKS_PER_SEC;

std::cout << "执行时间:" << elapsed << " 秒\n&quot;;
return 0;

}

注意:clock() 测量的是CPU时间,在多线程或系统空闲时可能不够准确。

小云雀 小云雀

剪映出品的AI视频和图片创作助手

小云雀 1949 查看详情 小云雀

封装成计时类便于复用

为了方便多次测量,可以封装一个简单的计时类。

示例:

#include <iostream>
#include <chrono>
<p>class Timer {
public:
Timer() { start = std::chrono::high_resolution_clock::now(); }</p><pre class="brush:php;toolbar:false;">void reset() { start = std::chrono::high_resolution_clock::now(); }

long long elapsed_microseconds() const {
    auto now = std::chrono::high_resolution_clock::now();
    return std::chrono::duration_cast<std::chrono::microseconds>(now - start).count();
}

long long elapsed_milliseconds() const {
    return elapsed_microseconds() / 1000;
}

private: std::chrono::high_resolution_clock::time_point start; };

// 使用示例 int main() { Timer timer; for (int i = 0; i

这种方式适合在多个地方重复使用,提升代码整洁度。

使用第三方库(如 Google Benchmark)

对于更专业的性能测试,可以使用 Google Benchmark 库,它能自动处理多次运行、统计平均值、标准差等。

虽然配置稍复杂,但在做性能对比或微基准测试时非常强大。

GitHub 地址:https://www.php.cn/link/706e79e774e8345ecccc7ed401793d9e

基本上就这些。日常开发中用 chrono 就足够了,简单、精准、可读性强。

以上就是c++++如何测量代码的执行时间_C++计算函数运行时长的几种方式的详细内容,更多请关注其它相关文章!


# 多线程  # 淘宝seo信息  # 整站优化seo上海  # 营销推广怎么申诉  # 商洛矩阵seo不做行吗  # 安徽省农机推广网站  # 佳木斯建设局网站  # 东莞需要网站建设  # 沙河如何把自己网站优化  # 广元营销推广方案策划  # 绍兴网站建设排名前十  # 你可以  # 的是  # 复用  # 尼克  # git  # 时长  # 几种  # 第三方  # 执行时间  # c++开发  # 性能测试  # google  # stream  # ios  # c++  # ai  # github  # go 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: KFC早餐时段怎么领特惠代码_KFC早餐订餐优惠代码获取与使用说明  word邮件合并后日期格式不对怎么改_Word邮件合并日期格式修改方法  漫蛙manwa2最新登录网址_漫蛙manwa2手机网页版入口  Django AJAX 文件上传教程:解决图片无法保存到模型的常见问题  冬*霸灯泡不亮怎么办_浴霸取暖灯一盏不亮的灯座清洁修复法  曝R星经典之作开发图 设计简陋但信息密集!  Lar*el 8 多关键词数据库搜索优化实践  C++ map遍历方法大全_C++ map迭代器使用总结  漫蛙manwa官网登录界面_漫蛙漫画网页版主站入口  Go RPC HTTP服务正确实现与常见陷阱解析  快速CSGO开箱网站指南 CSGO开箱平台推荐  win11怎么查看应用耗电情况 Win11电池设置查看应用能耗排行榜【优化】  Lar*el如何正确地在控制器和模型之间分配逻辑_Lar*el代码职责分离与架构建议  vivo手机参数配置怎么增强信号_vivo手机参数配置信号增强方法  百度浏览器字体显示异常偏小_百度浏览器字体渲染修复方案  C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入  小红书网页版入口链接分享 小红书官网直接进  LINQ to XML为何解析失败? 深入理解C# XDocument的异常处理  如何在离线环境中使用Composer_Composer离线安装依赖包的技巧与策略  抖音怎么赚钱_抖音创作者变现方法与途径指南  React中useState与局部变量:理解组件状态管理与渲染机制  微信群消息显示延迟如何解决 微信群消息刷新优化方法  文心一言怎样用批量生成做多版文案_文心一言用批量生成做多版文案【批量创作】  抖音网页版怎么|直播|_抖音网页版开播操作指南  sublime怎么进行远程开发编辑_配置rsub/rmate实现sublime编辑服务器文件  树莓派传感器触发:通过Twilio API发送WhatsApp消息教程  在J*a中如何捕获IndexOutOfBoundsException_索引越界异常防护方法说明  composer 和 npm/yarn 在管理依赖方面有什么核心思想差异?  Windows10怎么开启存储感知 Windows10系统设置自动清理临时文件释放C盘空间【教程】  QQ邮箱网页版登录入口 QQ邮箱官方在线使用平台  如何提高微信支付的安全性_微信支付安全防护与设置建议  解决macOS上安装pyhdf时‘hdf.h’文件缺失的编译错误  qq邮箱日历功能怎么用_创建日程与会议邀请的技巧  c++如何使用TBB库进行任务并行_c++ Intel线程构建模块  Typer应用中动态命令行参数的解析与处理  如何解决电商平台定制报价请求的“黑洞”问题,SprykerQuoteRequest模块助你提升客户体验与销售效率  基于动态规划的房屋花卉种植最小成本算法详解  批改网学生版PC登录 批改网官网登录系统入口  在J*a中如何在J*a中使用异常机制记录错误日志_异常日志实践经验  微信网页版官方快速登录入口 微信网页版网页版账号直达  b站如何看历史记录_b站观看历史找回方法  css元素hover动画延迟生效怎么办_使用animation-delay调整触发时间  Django表单提交验证失败后保持字段值不刷新  深入理解J*aScript中的B样条曲线与节点向量生成  jQuery Mask 插件中实现电话号码固定前导零的教程  如何在CSS中使用visited与link控制链接颜色_visited link伪类配合  Shopware订单对象中获取产品自定义字段的正确方法  MongoDB聚合管道:正确匹配对象数组中_id的方法  修复二维数组索引越界异常:一维循环到二维坐标的正确映射  mc.js游戏直达 mc.js网页免下载版本秒进地址 

搜索