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

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

 更新時間:2019年04月07日 21:07:59   作者:Lzpong  
這篇文章主要介紹了C++ 獲取進(jìn)程CPU占用率,需要的朋友可以參考下

核心代碼

// 時間轉(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;
  //上一次的時間
  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(),返回一個當(dāng)前進(jìn)程的句柄
(2)定義一個保存內(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. // 缺頁中斷次數(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. // 使用頁面緩存池高峰
SIZE_T QuotaPagedPoolUsage;                             Current paged pool usage, in bytes.// 使用頁面緩存池
SIZE_T QuotaPeakNonPagedPoolUsage;                         Peak nonpaged pool usage, in bytes.// 使用非分頁緩存池高峰
SIZE_T QuotaNonPagedPoolUsage;                          Current nonpaged pool usage, in bytes.// 使用非分頁緩存池
SIZE_T PagefileUsage;                              Current space allocated for the pagefile, in bytes.Those pages may or may not be in memory.// 使用分頁文件
SIZE_T PeakPagefileUsage;                             Peak space allocated for the pagefile, in bytes.// 使用分頁文件高峰
} PROCESS_MEMORY_COUNTERS, *PPROCESS_MEMORY_COUNTERS;

(3)獲取當(dāng)前進(jìn)程的內(nèi)存信息,保存到結(jié)構(gòu)體pmc中(第二個參數(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(),返回一個進(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使用時間 通過調(diào)用GetProcessTimes()
函數(shù)原型如下:

BOOL
WINAPI
GetProcessTimes(
__in HANDLE hProcess,                    需要獲取相關(guān)時間的進(jìn)程句柄
__out LPFILETIME lpCreationTime,          進(jìn)程的創(chuàng)建時間
__out LPFILETIME lpExitTime,            進(jìn)程的退出時間
__out LPFILETIME lpKernelTime,           進(jìn)程在內(nèi)核模式下的所有時間
__out LPFILETIME lpUserTime            進(jìn)程在用戶模式下的所有時間
);

CPU使用時間=(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占用時間-過去的CPU占用時間)/系統(tǒng)時間差

注:系統(tǒng)時間差可以通過GetSystemTimeAsFileTime()獲取,然后在轉(zhuǎn)換為int64類型即可,自定義轉(zhuǎn)換方法如下:

__int64 FileTimeToInt64(const FILETIME& time) 
{ 

  ULARGE_INTEGER tt; //64位無符號整型值
  tt.LowPart = time.dwLowDateTime; 
  tt.HighPart = time.dwHighDateTime;
  return(tt.QuadPart); //返回整型值

}

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

相關(guān)文章

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

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

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

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

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

    C++段錯誤(Segmentation fault)快速定位的解決方法

    寫過C++的朋友都知道,有時候程序編譯通過,并不能代表程序就是對的,在linux下做開發(fā)時,經(jīng)常會遇到跑崩潰的情況,但是在終端只會報(bào)Segmentation fault,如果工程代碼量少,你還能重新debug一下慢慢找,本文給大家介紹了C++段錯誤的快速定位,需要的朋友可以參考下
    2024-07-07
  • C++線性時間的排序算法分析

    C++線性時間的排序算法分析

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

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

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

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

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

    Qt常用容器類的使用

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

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

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

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

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

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

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

最新評論