欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++ 獲取進(jìn)程CPU占用率

 更新時(shí)間:2019年04月07日 21:07:59   作者:Lzpong  
這篇文章主要介紹了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); //返回整型值

}

這篇文章就介紹到這了,需要的朋友可以參考一下。

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)冒泡排序算法

    C語(yǔ)言實(shí)現(xiàn)冒泡排序算法

    冒泡排序(Bubble Sort),是一種計(jì)算機(jī)科學(xué)領(lǐng)域的較簡(jiǎn)單的排序算法。它重復(fù)地走訪過(guò)要排序的數(shù)列,一次比較兩個(gè)元素,如果他們的順序錯(cuò)誤就把他們交換過(guò)來(lái)。走訪數(shù)列的工作是重復(fù)地進(jìn)行直到?jīng)]有再需要交換,也就是說(shuō)該數(shù)列已經(jīng)排序完成。
    2015-03-03
  • 詳解C++編程中的變量相關(guān)知識(shí)

    詳解C++編程中的變量相關(guān)知識(shí)

    這篇文章主要介紹了詳解C++編程中的變量相關(guān)知識(shí),是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • C++段錯(cuò)誤(Segmentation fault)快速定位的解決方法

    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-07
  • C++線性時(shí)間的排序算法分析

    C++線性時(shí)間的排序算法分析

    這篇文章主要介紹了C++線性時(shí)間的排序算法分析,是非常經(jīng)典的非比較排序算法,對(duì)于C++程序員有很大的借鑒價(jià)值,需要的朋友可以參考下
    2014-08-08
  • 詳解C++編程中的文件流與字符串流

    詳解C++編程中的文件流與字符串流

    這篇文章主要介紹了C++編程中的文件流與字符串流,是C++入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄功能

    C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄功能

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Qt常用容器類(lèi)的使用

    Qt常用容器類(lèi)的使用

    本文主要介紹了Qt常用容器類(lèi)的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • C語(yǔ)言三子棋小游戲?qū)崿F(xiàn)全程

    C語(yǔ)言三子棋小游戲?qū)崿F(xiàn)全程

    三子棋是一種民間傳統(tǒng)游戲,又叫九宮棋、圈圈叉叉、一條龍、井字棋等。將正方形對(duì)角線連起來(lái),相對(duì)兩邊依次擺上三個(gè)雙方棋子,只要將自己的三個(gè)棋子走成一條線,對(duì)方就算輸了,想用c語(yǔ)言做出這個(gè)游戲,事實(shí)上也是比較簡(jiǎn)單的,下面通過(guò)c語(yǔ)言進(jìn)行對(duì)五子棋的分析
    2022-05-05
  • 舉例解析設(shè)計(jì)模式中的工廠方法模式在C++編程中的運(yùn)用

    舉例解析設(shè)計(jì)模式中的工廠方法模式在C++編程中的運(yùn)用

    這篇文章主要介紹了設(shè)計(jì)模式中的工廠方法模式在C++編程中的運(yùn)用,文中也對(duì)簡(jiǎn)單工廠模式和工廠方法模式進(jìn)行了簡(jiǎn)單的對(duì)比,需要的朋友可以參考下
    2016-03-03
  • 詳解C++中常用的四種類(lèi)型轉(zhuǎn)換方式

    詳解C++中常用的四種類(lèi)型轉(zhuǎn)換方式

    這篇文章主要為大家詳細(xì)介紹了C++中常用的四種類(lèi)型轉(zhuǎn)換方式:static_cast<Type>、dynamic_cast<Type>、const_case<Type>和reinterpret_cast,感興趣的可以了解一下
    2022-08-08

最新評(píng)論