0

0

c++中如何计算程序的运行时间 _c++程序运行时间测量技巧

下次还敢

下次还敢

发布时间:2025-10-15 18:10:02

|

407人浏览过

|

来源于php中文网

原创

使用chrono库中的steady_clock可准确测量C++程序运行时间,推荐封装Timer类以复用代码,通过duration_cast转换时间单位,避免使用低精度的clock()函数。

c++中如何计算程序的运行时间 _c++程序运行时间测量技巧

在C++中测量程序运行时间,常用的方法是使用标准库中的 chrono 模块。它提供了高精度的时间测量功能,适用于从毫秒到纳秒级别的计时需求。下面介绍几种实用的技巧来准确测量C++程序或代码段的运行时间。

使用 chrono 高精度时钟

C++11 引入了 chrono 库,推荐使用 steady_clock,因为它不受系统时间调整的影响,适合做间隔测量。

基本用法如下:

#include 
#include 

int main() { auto start = std::chrono::steady_clock::now();

// 要测量的代码段
for (int i = 0; i < 1000000; ++i) {
    // 模拟工作
}

auto end = std::chrono::steady_clock::now();
auto duration = std::chrono::duration_cast(end - start);

std::cout << "耗时: " << duration.count() << " 微秒" << std::endl;
return 0;

}

封装成可复用的计时器类

如果需要多次测量不同部分的代码,可以封装一个简单的计时器类,提升代码整洁度。

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

Mulan AI
Mulan AI

画布式AI视频创作平台,轻松制作爆款视频

下载
#include 
#include 

class Timer { public: Timer() { reset(); }

void reset() {
    m_start = std::chrono::steady_clock::now();
}

int64_t elapsed_ms() const {
    return std::chrono::duration_cast(
        std::chrono::steady_clock::now() - m_start
    ).count();
}

int64_t elapsed_us() const {
    return std::chrono::duration_cast(
        std::chrono::steady_clock::now() - m_start
    ).count();
}

private: std::chrono::steady_clock::time_point m_start; };

使用示例:

Timer t;
// 执行某段操作
some_function();
std::cout << "耗时: " << t.elapsed_ms() << " ms" << std::endl;

测量函数执行时间的简易方式

对于单次调用某个函数想快速查看耗时,可以直接内联测量:

auto start = std::chrono::steady_clock::now();
my_function();
auto end = std::chrono::steady_clock::now();

auto ms = std::chrono::duration_cast(end - start); std::cout << "函数耗时: " << ms.count() << " ms" << std::endl;

这种写法简单直接,适合调试和性能分析阶段。

基本上就这些。使用 std::chrono::steady_clock 是目前最推荐的方式,避免使用过时的 clock() 函数,因为它精度低且行为依赖平台。合理利用 chrono 的类型转换,能灵活输出毫秒、微秒或纳秒级别的时间,满足不同场景需求。

相关专题

更多
C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

299

2025.07.15

c++ 根号
c++ 根号

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

45

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

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

46

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

205

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

343

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

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

100

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

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

73

2026.01.22

php会话教程合集
php会话教程合集

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

78

2026.01.22

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号