如何在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/zh-hant/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

發表回復

登錄後才能評論