如何在C++中实现高效计时功能

一、chrono库

在C++11标准中,提供了std::chrono库,用于进行时间相关的处理。

首先,我们需要一个时钟,其中,系统时钟由std::chrono::system_clock提供,其用法如下:

#include <iostream>
#include <chrono>

int main()
{
    auto start = std::chrono::system_clock::now();
    
    // do something
    
    auto end = std::chrono::system_clock::now();
    auto elapsed = std::chrono::duration_cast<std::chrono::milliseconds>(end - start);
    
    std::cout << "Elapsed time: " << elapsed.count() << "ms\n";
    
    return 0;
}

这段代码中用到了std::chrono::system_clock::now()来获取当前时间,然后用auto关键字来推导类型,省略了时间类型的繁琐定义。duration_cast<std::chrono::milliseconds>用于将时间转换为“毫秒”类型的时间,elapsed.count()则得到毫秒数。

二、高精度计时器

上文提到的chrono库可以很好地计时,但其时间精度在微妙级别,对于需要更高精度的计时需求,我们可以使用一个高精度计时器。

代码示例:

#include <iostream>
#include <chrono>

class Timer
{
public:
    Timer() { m_startTimepoint = std::chrono::high_resolution_clock::now(); }
    ~Timer()
    {
        Stop();
    }
    void Stop()
    {
        auto endTimepoint = std::chrono::high_resolution_clock::now();
        auto start = std::chrono::time_point_cast<std::chrono::microseconds>(m_startTimepoint);
        auto end = std::chrono::time_point_cast<std::chrono::microseconds>(endTimepoint);
        auto duration = end.time_since_epoch() - start.time_since_epoch();
        long long us = duration.count();
        double ms = us * 0.001;
        double s = ms * 0.001;
        std::cout << us << "us (" << ms << "ms) (" << s << "s)\n";
    }
private:
    std::chrono::time_point<std::chrono::high_resolution_clock> m_startTimepoint;
};

int main()
{
    Timer timer;
    
    // do something
    
    return 0;
}

这是一个计时器类,其构造函数中通过std::chrono::high_resolution_clock::now()获取计时器开始的时间点,随后在析构函数中结束计时,并计算了微秒、毫秒、秒三种时间单位,并将其输出。在需要计时的代码块中,只需要定义一个计时器类的对象,其析构函数会在代码块执行结束时自动调用。

三、使用clock()函数

C++标准库提供了std::clock()函数用于计算CPU时间。

示例代码:

#include <iostream>
#include <ctime>

int main()
{
    std::clock_t start, end;
    start = std::clock();
    
    // do something
    
    end = std::clock();
    
    double time_used = static_cast<double>(end - start) / CLOCKS_PER_SEC;
    
    std::cout << "CPU time used: " << time_used << "s\n";
    
    return 0;
}

在代码执行期间,clock()函数会返回CPU经过的时间,单位为时钟周期数,这里使用CLOCKS_PER_SEC将其转化为秒,并输出结果。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/272441.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-17 13:56
下一篇 2024-12-17 13:56

相关推荐

  • 如何在PyCharm中安装OpenCV?

    本文将从以下几个方面详细介绍如何在PyCharm中安装OpenCV。 一、安装Python 在安装OpenCV之前,请确保已经安装了Python。 如果您还没有安装Python,可…

    编程 2025-04-29
  • 如何在Python中实现平方运算?

    在Python中,平方运算是常见的数学运算之一。本文将从多个方面详细阐述如何在Python中实现平方运算。 一、使用乘法运算实现平方 平方运算就是一个数乘以自己,因此可以使用乘法运…

    编程 2025-04-29
  • 如何在Python中找出所有的三位水仙花数

    本文将介绍如何使用Python语言编写程序,找出所有的三位水仙花数。 一、什么是水仙花数 水仙花数也称为自恋数,是指一个n位数(n≥3),其各位数字的n次方和等于该数本身。例如,1…

    编程 2025-04-29
  • 如何在树莓派上安装Windows 7系统?

    随着树莓派的普及,许多用户想在树莓派上安装Windows 7操作系统。 一、准备工作 在开始之前,需要准备以下材料: 1.树莓派4B一台; 2.一张8GB以上的SD卡; 3.下载并…

    编程 2025-04-29
  • 如何在代码中打出正确的横杆

    在编程中,横杆是一个很常见的符号,但是有些人可能会在打横杆时出错。本文将从多个方面详细介绍如何在代码中打出正确的横杆。 一、正常使用横杆 在代码中,直接使用“-”即可打出横杆。例如…

    编程 2025-04-29
  • Java和Python哪个功能更好

    对于Java和Python这两种编程语言,究竟哪一种更好?这个问题并没有一个简单的答案。下面我将从多个方面来对Java和Python进行比较,帮助读者了解它们的优势和劣势,以便选择…

    编程 2025-04-29
  • 如何在Spring Cloud中整合腾讯云TSF

    本篇文章将介绍如何在Spring Cloud中整合腾讯云TSF,并提供完整的代码示例。 一、TSF简介 TSF (Tencent Serverless Framework)是腾讯云…

    编程 2025-04-29
  • 如何在服务器上运行网站

    想要在服务器上运行网站,需要按照以下步骤进行配置和部署。 一、选择服务器和域名 想要在服务器上运行网站,首先需要选择一台云服务器或者自己搭建的服务器。云服务器会提供更好的稳定性和可…

    编程 2025-04-28
  • 如何在Python中输出汉字和数字

    本文将从多个方面详细介绍如何在Python中输出汉字和数字,并提供代码示例。 一、输出汉字 要在Python中输出汉字,需要先确保Python默认编码是utf-8,这可以通过在代码…

    编程 2025-04-28
  • 如何在谷歌中定位系统弹框元素

    本文将从以下几个方面为大家介绍如何在谷歌中准确地定位系统弹框元素。 一、利用开发者工具 在使用谷歌浏览器时,我们可以通过它自带的开发者工具来定位系统弹框元素。 首先,我们可以按下F…

    编程 2025-04-28

发表回复

登录后才能评论