0

0

C++ 怎么计算程序运行时间 C++ chrono高精度计时器代码【测试】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-26 11:02:03

|

666人浏览过

|

来源于php中文网

原创

最可靠跨平台高精度计时应优先使用 std::chrono::steady_clock,它语义明确、单调稳定;仅当需纳秒级精度且确认平台支持时才考虑 high_resolution_clock。

c++ 怎么计算程序运行时间 c++ chrono高精度计时器代码【测试】

std::chrono::high_resolution_clock 获取纳秒级起止时间

这是 C++11 起最可靠、跨平台的高精度计时方式,底层通常映射到系统最高精度时钟(如 Linux 的 CLOCK_MONOTONIC 或 Windows 的 QueryPerformanceCounter),不会受系统时间调整影响。

关键点:必须用同一时钟类型获取开始和结束时间,否则差值无定义;time_point 本身不直接可读,需用 duration_cast 转成具体单位。

常见错误:用 system_clock 测运行时间——它反映的是挂钟时间,可能被 NTP 调整或手动修改,导致负值或跳变。

  • 起始时间:auto start = std::chrono::high_resolution_clock::now();
  • 结束时间:auto end = std::chrono::high_resolution_clock::now();
  • 计算毫秒:std::chrono::duration_cast<:chrono::milliseconds>(end - start).count()
  • 计算微秒:std::chrono::duration_cast<:chrono::microseconds>(end - start).count()
  • 计算纳秒(注意溢出风险):std::chrono::duration_cast<:chrono::nanoseconds>(end - start).count()

避免编译器优化干扰真实耗时测量

如果被测代码太简单(比如空循环或纯计算),编译器可能在 -O2 或更高优化级别下整个删掉,测出来永远是 0。必须确保结果被实际使用,或用 volatile / asm volatile 阻止优化。

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

典型场景:测一个函数执行时间,但返回值没被读取,编译器就认为该调用无副作用,直接优化掉。

  • 安全做法:把函数返回值赋给 volatile 变量,例如 volatile auto result = my_func();
  • 更通用做法(尤其对 void 函数):asm volatile("" ::: "memory"); 插入内存屏障,阻止指令重排和优化
  • 测试前加 std::chrono::high_resolution_clock::now(); 多次预热,减少首次调用 cache 缺失干扰(对短时间测量影响明显)

steady_clockhigh_resolution_clock 选哪个?

steady_clock 保证单调递增、不受系统时间调整影响,是“稳定时钟”语义的首选;high_resolution_clock 是实现定义的,C++ 标准只要求它是“当前系统支持的最高精度时钟”,但很多平台(如 GCC/libstdc++)让它直接 alias 到 steady_clock

Sheet+
Sheet+

Excel和GoogleSheets表格AI处理工具

下载

所以:优先用 steady_clock —— 它语义明确、行为可预测;只有当你明确需要纳秒级分辨率且确认平台支持时,才考虑 high_resolution_clock,但不要假设它一定比 steady_clock 更快。

  • 推荐写法:auto start = std::chrono::steady_clock::now();
  • 别依赖 high_resolution_clock::period::num / .den 判断精度,不同标准库实现差异大
  • Windows 上 MSVC 的 steady_clock 精度约 15.6ms(基于 GetTickCount64),此时应改用 high_resolution_clock(基于 QueryPerformanceCounter,精度 ~100ns)

完整可运行测试示例(含防优化 + 多次采样)

下面这段代码测一个简单循环的耗时,并取 3 次最小值(排除系统抖动干扰),同时防止编译器优化掉循环:

#include 
#include 

int main() { constexpr int iter = 1000000; volatile long sum = 0; // 防优化关键:volatile 变量

auto min_ns = std::chrono::nanoseconds::max();
for (int r = 0; r zuojiankuohaophpcn 3; ++r) {
    auto start = std::chrono::steady_clock::now();
    for (int i = 0; i zuojiankuohaophpcn iter; ++i) {
        sum += i;
    }
    auto end = std::chrono::steady_clock::now();
    auto ns = std::chrono::duration_castzuojiankuohaophpcnstd::chrono::nanosecondsyoujiankuohaophpcn(end - start).count();
    if (ns zuojiankuohaophpcn min_ns.count()) min_ns = std::chrono::nanoseconds(ns);
}

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Min time: " zuojiankuohaophpcnzuojiankuohaophpcn min_ns.count() zuojiankuohaophpcnzuojiankuohaophpcn " ns\n";
return 0;

}

注意 volatile long sum 和三次采样逻辑——真实性能测试中,单次测量意义不大,最小值比平均值更能反映“理想路径”开销。

真正难的不是写对那几行 now(),而是让被测代码不被优化、不被缓存干扰、不被调度器打断;这些细节不处理,测出来的数字只是幻觉。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2023.11.23

java中void的含义
java中void的含义

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

98

2025.11.27

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.10.23

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

730

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1128

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

799

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

454

2023.08.02

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

8

2026.01.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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