C++ 獲取進(jìn)程CPU占用率
核心代碼
// 時(shí)間轉(zhuǎn)換 static __int64 file_time_2_utc(const FILETIME* ftime) { LARGE_INTEGER li; li.LowPart = ftime->dwLowDateTime; li.HighPart = ftime->dwHighDateTime; return li.QuadPart; } // 獲得CPU的核數(shù) static int get_processor_number() { SYSTEM_INFO info; GetSystemInfo(&info); return (int)info.dwNumberOfProcessors; } // 獲取進(jìn)程CPU占用 int get_cpu_usage(int pid) { //cpu數(shù)量 static int processor_count_ = -1; //上一次的時(shí)間 static __int64 last_time_ = 0; static __int64 last_system_time_ = 0; FILETIME now; FILETIME creation_time; FILETIME exit_time; FILETIME kernel_time; FILETIME user_time; __int64 system_time; __int64 time; __int64 system_time_delta; __int64 time_delta; int cpu = -1; if(processor_count_ == -1) { processor_count_ = get_processor_number(); } GetSystemTimeAsFileTime(&now); HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, false, pid); if (!GetProcessTimes(hProcess, &creation_time, &exit_time, &kernel_time, &user_time)) { return -1; } system_time = (file_time_2_utc(&kernel_time) + file_time_2_utc(&user_time)) / processor_count_; time = file_time_2_utc(&now); if ((last_system_time_ == 0) || (last_time_ == 0)) { last_system_time_ = system_time; last_time_ = time; return -1; } system_time_delta = system_time - last_system_time_; time_delta = time - last_time_; if (time_delta == 0) return -1; cpu = (int)((system_time_delta * 100 + time_delta / 2) / time_delta); last_system_time_ = system_time; last_time_ = time; return cpu; }
以下是其它網(wǎng)友的補(bǔ)充
C++ 獲取進(jìn)程內(nèi)存占用和CPU利用率等信息
1.獲取內(nèi)存占用信息
獲取步驟:
(1)獲取當(dāng)前進(jìn)程句柄 使用GetCurrentProcess(),返回一個(gè)當(dāng)前進(jìn)程的句柄
(2)定義一個(gè)保存內(nèi)存信息的結(jié)構(gòu)體 PROCESS_MEMORY_COUNTERS pmc;
結(jié)構(gòu)體定義如下:
typedef struct _PROCESS_MEMORY_COUNTERS { DWORD cb; Size of the structure, in bytes.//結(jié)構(gòu)體大小 DWORD PageFaultCount; Number of page faults. // 缺頁(yè)中斷次數(shù) SIZE_T PeakWorkingSetSize; Peak working set size, in bytes. // 使用內(nèi)存高峰 SIZE_T WorkingSetSize; Current working set size, in bytes. // 當(dāng)前使用的內(nèi)存 SIZE_T QuotaPeakPagedPoolUsage; Peak paged pool usage, in bytes. // 使用頁(yè)面緩存池高峰 SIZE_T QuotaPagedPoolUsage; Current paged pool usage, in bytes.// 使用頁(yè)面緩存池 SIZE_T QuotaPeakNonPagedPoolUsage; Peak nonpaged pool usage, in bytes.// 使用非分頁(yè)緩存池高峰 SIZE_T QuotaNonPagedPoolUsage; Current nonpaged pool usage, in bytes.// 使用非分頁(yè)緩存池 SIZE_T PagefileUsage; Current space allocated for the pagefile, in bytes.Those pages may or may not be in memory.// 使用分頁(yè)文件 SIZE_T PeakPagefileUsage; Peak space allocated for the pagefile, in bytes.// 使用分頁(yè)文件高峰 } PROCESS_MEMORY_COUNTERS, *PPROCESS_MEMORY_COUNTERS;
(3)獲取當(dāng)前進(jìn)程的內(nèi)存信息,保存到結(jié)構(gòu)體pmc中(第二個(gè)參數(shù)) 使用GetProcessMemoryInfo()
API定義如下:
GetProcessMemoryInfo(
HANDLE Process, 獲取內(nèi)存使用情況的進(jìn)程句柄。
PPROCESS_MEMORY_COUNTERS ppsmemCounters, 返回內(nèi)存使用情況的結(jié)構(gòu)
DWORD cb 結(jié)構(gòu)的大小
);DE
2.獲取CPU利用率
獲取步驟:
(1)獲取當(dāng)前進(jìn)程句柄 通過(guò)OpenProcess(),返回一個(gè)進(jìn)程句柄
函數(shù)原型如下:
HANDLE OpenProcess( DWORD dwDesiredAccess, //渴望得到的訪問(wèn)權(quán)限(標(biāo)志) BOOL bInheritHandle, // 是否繼承句柄 DWORD dwProcessId// 進(jìn)程標(biāo)示符,可以通過(guò)getpid()獲取當(dāng)前進(jìn)程ID );
(2)獲取CPU使用時(shí)間 通過(guò)調(diào)用GetProcessTimes()
函數(shù)原型如下:
BOOL WINAPI GetProcessTimes( __in HANDLE hProcess, 需要獲取相關(guān)時(shí)間的進(jìn)程句柄 __out LPFILETIME lpCreationTime, 進(jìn)程的創(chuàng)建時(shí)間 __out LPFILETIME lpExitTime, 進(jìn)程的退出時(shí)間 __out LPFILETIME lpKernelTime, 進(jìn)程在內(nèi)核模式下的所有時(shí)間 __out LPFILETIME lpUserTime 進(jìn)程在用戶(hù)模式下的所有時(shí)間 );
CPU使用時(shí)間=(lpKernelTime+lpUserTime)/GetProcessNumber()(內(nèi)核數(shù))
內(nèi)核數(shù)獲取方法如下:
int GetProcessNumber() { SYSTEM_INFO info; GetSystemInfo(&info); return (int)info.dwNumberOfProcessors; }
(3)計(jì)算CPU利用率
CPU利用率=(現(xiàn)在的CPU占用時(shí)間-過(guò)去的CPU占用時(shí)間)/系統(tǒng)時(shí)間差
注:系統(tǒng)時(shí)間差可以通過(guò)GetSystemTimeAsFileTime()獲取,然后在轉(zhuǎn)換為int64類(lèi)型即可,自定義轉(zhuǎn)換方法如下:
__int64 FileTimeToInt64(const FILETIME& time) { ULARGE_INTEGER tt; //64位無(wú)符號(hào)整型值 tt.LowPart = time.dwLowDateTime; tt.HighPart = time.dwHighDateTime; return(tt.QuadPart); //返回整型值 }
這篇文章就介紹到這了,需要的朋友可以參考一下。
- C++中rapidjson組裝繼續(xù)簡(jiǎn)化的方法
- C++中rapidjson將嵌套map轉(zhuǎn)為嵌套json的講解
- C++中rapidjson將map轉(zhuǎn)為json的方法
- 詳解C++中虛析構(gòu)函數(shù)的作用及其原理分析
- C++中rapidjson組裝map和數(shù)組array的代碼示例
- 用C/C++代碼檢測(cè)ip能否ping通(配合awk和system可以做到批量檢測(cè))
- c++文件監(jiān)控之FileSystemWatcher
- vc++ 監(jiān)控指定路徑下文件變化實(shí)現(xiàn)代碼
- C++獲取MD5算法實(shí)現(xiàn)代碼
- C++類(lèi)中變量也可以是引用的代碼實(shí)例
相關(guān)文章
C++段錯(cuò)誤(Segmentation fault)快速定位的解決方法
寫(xiě)過(guò)C++的朋友都知道,有時(shí)候程序編譯通過(guò),并不能代表程序就是對(duì)的,在linux下做開(kāi)發(fā)時(shí),經(jīng)常會(huì)遇到跑崩潰的情況,但是在終端只會(huì)報(bào)Segmentation fault,如果工程代碼量少,你還能重新debug一下慢慢找,本文給大家介紹了C++段錯(cuò)誤的快速定位,需要的朋友可以參考下2024-07-07C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄功能
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09舉例解析設(shè)計(jì)模式中的工廠方法模式在C++編程中的運(yùn)用
這篇文章主要介紹了設(shè)計(jì)模式中的工廠方法模式在C++編程中的運(yùn)用,文中也對(duì)簡(jiǎn)單工廠模式和工廠方法模式進(jìn)行了簡(jiǎn)單的對(duì)比,需要的朋友可以參考下2016-03-03