0

0

C++如何计算程序运行时间?(代码示例)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-12-29 12:24:08

|

560人浏览过

|

来源于php中文网

原创

std::chrono是C++11起最推荐的计时方式,精度高、跨平台、类型安全;用high_resolution_clock测毫秒级耗时适合小段代码,可依需转微秒、纳秒或带小数的秒,注意避免clock()误用、编译器优化及单次测量干扰。

c++如何计算程序运行时间?(代码示例)

std::chrono 是 C++11 起最推荐的方式,精度高、跨平台、类型安全,比老式的 clock()time() 更可靠。

用 high_resolution_clock 测毫秒级耗时

适合测量小段代码(如算法执行、函数调用)的精确耗时:

#include <iostream>
#include <chrono>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class="brush:php;toolbar:false;">// 你要测的代码,比如一个简单循环
volatile int sum = 0;  // volatile 防止被编译器优化掉
for (int i = 0; i < 1000000; ++i) {
    sum += i;
}

auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);

std::cout << "耗时: " << duration.count() << " 毫秒\n";
return 0;

}

测微秒或纳秒,只需换 duration_cast

根据需要调整时间单位,不改变计时逻辑:

  • 微秒std::chrono::duration_cast<:chrono::microseconds>(end - start)</:chrono::microseconds>
  • 纳秒std::chrono::duration_cast<:chrono::nanoseconds>(end - start)</:chrono::nanoseconds>
  • 秒(带小数)std::chrono::duration<double>(end - start).count()</double>

避免常见坑

几个容易出错但很关键的细节:

OpenCV
OpenCV

开源计算机视觉库拥有超过2500个算法,提供详细的文档和实时计算机视觉的示例代码。它可以在Windows、Linux、Mac OS X、Android、iOS上运行,并通过JavaScript在您的浏览器中使用。语言:C++、Python、Julia、Javascript主页:https://opencv.org问答论坛:https://forum.opencv.org/文档:https://docs.opencv.org源代码:https://github.com/opencv请特别关注我们的教程!ht

下载

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

  • 别用 clock() 测 wall-clock 时间——它返回的是 CPU 时间,多线程下不准,且单位是 CLOCKS_PER_SEC,非秒
  • 别在 Release 模式下测空循环或无副作用代码——编译器可能直接优化掉,结果为 0
  • 单次测量易受干扰,要测得准可跑多次取平均,或用 std::chrono::steady_clock(更稳定,不随系统时间调整)
  • 如果测整个程序启动到结束,main() 开头记 start,结尾记 end 即可,无需额外线程

基本上就这些。用 chrono 三行搞定,清晰又靠谱。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

201

2023.11.20

c++怎么把double转成int
c++怎么把double转成int

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

294

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

105

2025.10.23

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

372

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

27

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

102

2026.02.06

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

0

2026.03.04

热门下载

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

相关下载

更多

精品课程

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

共1课时 | 0.1万人学习

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

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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