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)程句柄 通過OpenProcess(),返回一個(gè)進(jìn)程句柄
函數(shù)原型如下:
HANDLE OpenProcess( DWORD dwDesiredAccess, //渴望得到的訪問權(quán)限(標(biāo)志) BOOL bInheritHandle, // 是否繼承句柄 DWORD dwProcessId// 進(jìn)程標(biāo)示符,可以通過getpid()獲取當(dāng)前進(jìn)程ID );
(2)獲取CPU使用時(shí)間 通過調(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)程在用戶模式下的所有時(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í)間-過去的CPU占用時(shí)間)/系統(tǒng)時(shí)間差
注:系統(tǒng)時(shí)間差可以通過GetSystemTimeAsFileTime()獲取,然后在轉(zhuǎn)換為int64類型即可,自定義轉(zhuǎn)換方法如下:
__int64 FileTimeToInt64(const FILETIME& time)
{
ULARGE_INTEGER tt; //64位無符號(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++類中變量也可以是引用的代碼實(shí)例
相關(guān)文章
C++段錯(cuò)誤(Segmentation fault)快速定位的解決方法
寫過C++的朋友都知道,有時(shí)候程序編譯通過,并不能代表程序就是對(duì)的,在linux下做開發(fā)時(shí),經(jīng)常會(huì)遇到跑崩潰的情況,但是在終端只會(huì)報(bào)Segmentation fault,如果工程代碼量少,你還能重新debug一下慢慢找,本文給大家介紹了C++段錯(cuò)誤的快速定位,需要的朋友可以參考下2024-07-07
C語(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

