亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++記錄程序運(yùn)行時(shí)間的四種方法

 更新時(shí)間:2025年03月17日 11:29:00   作者:草海桐  
在學(xué)習(xí)過(guò)程中很重要的一個(gè)必會(huì)的小技巧:計(jì)算某一段代碼的執(zhí)行時(shí)間,可以用來(lái)分析代碼的效率和算法的時(shí)間復(fù)雜度等等(個(gè)人主要是在總結(jié)各種排序算法時(shí)遇到的這個(gè)方法),本文給大家介紹了C++記錄程序運(yùn)行時(shí)間的四種方法,需要的朋友可以參考下

1. 使用 <chrono> 庫(kù)(C++11及以后版本)

<chrono> 庫(kù)提供了高精度的時(shí)間測(cè)量功能。

#include <iostream>  
#include <chrono>  
  
int main() {  
    auto start = std::chrono::high_resolution_clock::now();  
  
    // Your code here  
    // ...  
  
    auto stop = std::chrono::high_resolution_clock::now();  
    auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(stop - start).count();  
  
    std::cout << "Elapsed time: " << duration << " ms\n";  
  
    return 0;  
}

2. 使用 <ctime> 庫(kù)(較舊但常用的方法)

<ctime> 庫(kù)提供了基于系統(tǒng)時(shí)間的函數(shù)clock()。

#include <iostream>  
#include <ctime>  
  
int main() {  
    clock_t start = clock(); //也可以double start = clock(); 
  
    // Your code here  
    // ...  
  
    clock_t end = clock();  
    double cpu_time_used = static_cast<double>(end - start) / CLOCKS_PER_SEC;
    //  /CLOCKS_PER_SEC將結(jié)果轉(zhuǎn)為以秒為單位
  
    std::cout << "CPU time used: " << cpu_time_used << " s\n";  
  
    return 0;  
}

3、使用第三方庫(kù)(如Boost.Timer)

Boost庫(kù)提供了一個(gè)計(jì)時(shí)器模塊,用于測(cè)量代碼塊的執(zhí)行時(shí)間。

首先,你需要安裝 Boost庫(kù),并在項(xiàng)目中包含Boost.Timer頭文件。

#include <boost/timer/timer.hpp>  
#include <iostream>  
  
int main() {  
    boost::timer::auto_cpu_timer t; // 自動(dòng)測(cè)量和打印執(zhí)行時(shí)間  
  
    // Your code here  
    // ...  
  
    return 0;  
}

4. 使用Windows API函數(shù)(Windows平臺(tái)特有)

4.1 使用 GetTickCount()

這個(gè)函數(shù)返回從系統(tǒng)啟動(dòng)開(kāi)始經(jīng)過(guò)的毫秒數(shù)。GetTickCount() 的精度在1到15毫秒之間,并且其值會(huì)在大約49.7天后回繞。

#include <windows.h>  
#include <iostream>  
  
int main() {  
    DWORD start = GetTickCount();  
    // ... 執(zhí)行你的代碼 ...  
    DWORD end = GetTickCount();  
    std::cout << "程序運(yùn)行時(shí)間: " << (end - start) << " 毫秒" << std::endl;  
    return 0;  
}

4.2 使用 QueryPerformanceCounter() 和 QueryPerformanceFrequency()

這兩個(gè)函數(shù)提供了更高的精度,通常在微秒級(jí)別。

#include <windows.h>  
#include <iostream>  
  
int main() {  
    LARGE_INTEGER start, end, freq;  
    QueryPerformanceFrequency(&freq);  
    QueryPerformanceCounter(&start);  
    // ... 執(zhí)行你的代碼 ...  
    QueryPerformanceCounter(&end);  
    double elapsedTime = (double)(end.QuadPart - start.QuadPart) / freq.QuadPart * 1000.0; // 毫秒  
    std::cout << "程序運(yùn)行時(shí)間: " << elapsedTime << " 毫秒" << std::endl;  
    return 0;  
}

到此這篇關(guān)于C++記錄程序運(yùn)行時(shí)間的四種方法的文章就介紹到這了,更多相關(guān)C++程序運(yùn)行時(shí)間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Qt中互斥鎖QMutex和QMutexLocker的使用

    Qt中互斥鎖QMutex和QMutexLocker的使用

    本文主要介紹了Qt中互斥鎖QMutex和QMutexLocker的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • 關(guān)于C語(yǔ)言 文件讀寫 feof 函數(shù)

    關(guān)于C語(yǔ)言 文件讀寫 feof 函數(shù)

    這篇文章主要給大家分享的是關(guān)于C語(yǔ)言文件讀寫 feof 函數(shù) ,feof 是 C 語(yǔ)言標(biāo)準(zhǔn)庫(kù)函數(shù),其功能是檢測(cè)文件結(jié)束符,如果文件結(jié)束,則返回非 0 值,否則返回 0,感興趣的小伙伴請(qǐng)跟小編一起來(lái)看看下面文章的內(nèi)容吧
    2021-10-10
  • Linux C/C++實(shí)現(xiàn)DNS客戶端請(qǐng)求域名IP的示例代碼

    Linux C/C++實(shí)現(xiàn)DNS客戶端請(qǐng)求域名IP的示例代碼

    DNS全稱:Domain Name System,域名解析系統(tǒng),是互聯(lián)網(wǎng)的一項(xiàng)服務(wù),本文主要介紹了C/C++如何實(shí)現(xiàn)DNS客戶端請(qǐng)求域名IP,感興趣的可以了解下
    2024-03-03
  • 使用C語(yǔ)言判斷英文字符大小寫的方法

    使用C語(yǔ)言判斷英文字符大小寫的方法

    這篇文章主要介紹了使用C語(yǔ)言判斷英文字符大小寫的方法,分別為isupper()函數(shù)和islower()函數(shù)的使用,需要的朋友可以參考下
    2015-08-08
  • Matlab繪制有趣的羅盤時(shí)鐘的示例代碼

    Matlab繪制有趣的羅盤時(shí)鐘的示例代碼

    這篇文章主要介紹了如何利用Matlab實(shí)現(xiàn)繪制有趣的羅盤時(shí)鐘,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定的幫助,需要的可以參考一下
    2023-01-01
  • C語(yǔ)言用封裝方法實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲

    C語(yǔ)言用封裝方法實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言用封裝方法實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C++實(shí)現(xiàn)指針空值的示例代碼

    C++實(shí)現(xiàn)指針空值的示例代碼

    本文主要介紹了C++實(shí)現(xiàn)指針空值的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C++ 輸入scanf()和輸出printf()的操作

    C++ 輸入scanf()和輸出printf()的操作

    這篇文章主要介紹了C++ 輸入scanf()和輸出printf()的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • VSCode插件開(kāi)發(fā)全攻略之打包、發(fā)布、升級(jí)的詳細(xì)教程

    VSCode插件開(kāi)發(fā)全攻略之打包、發(fā)布、升級(jí)的詳細(xì)教程

    這篇文章主要介紹了VSCode插件開(kāi)發(fā)全攻略之打包、發(fā)布、升級(jí)的教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • C語(yǔ)言關(guān)鍵字const和指針的結(jié)合使用

    C語(yǔ)言關(guān)鍵字const和指針的結(jié)合使用

    這篇文章主要介紹了C語(yǔ)言關(guān)鍵字const和指針的結(jié)合,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02

最新評(píng)論