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)文章
關(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-10Linux 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-03C語(yǔ)言用封裝方法實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言用封裝方法實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05VSCode插件開(kāi)發(fā)全攻略之打包、發(fā)布、升級(jí)的詳細(xì)教程
這篇文章主要介紹了VSCode插件開(kāi)發(fā)全攻略之打包、發(fā)布、升級(jí)的教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05C語(yǔ)言關(guān)鍵字const和指針的結(jié)合使用
這篇文章主要介紹了C語(yǔ)言關(guān)鍵字const和指針的結(jié)合,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02