c++获得cpu厂商_获取CPU占有率的C++类

获取CPU占有率的C++类:Windows系统CPU占有率,实时监视CPU占有率,对cpu使用率有要求的系统可以参考使用。

#pragma once

#define SystemBasicInformation 0

#define SystemPerformanceInformation 2

#define SystemTimeInformation 3

#define Li2Double(x) ((double)((x).HighPart) * 4.294967296E9 + (double)((x).LowPart))

class CCpuUsage

{

public:

CCpuUsage();

~CCpuUsage();

public:

int GetCpuUsage(); //得到系统cpu利用率

int SetRefreshInterval(int milli_sec); //定时刷新间隔

private:

//类型定义

typedef LONG (WINAPI *PROCNTQSI)(UINT,PVOID,ULONG,PULONG);

typedef struct

{

DWORD dwUnknown1;

ULONG uKeMaximumIncrement;

ULONG uPageSize;

ULONG uMmNumberOfPhysicalPages;

ULONG uMmLowestPhysicalPage;

ULONG uMmHighestPhysicalPage;

ULONG uAllocationGranularity;

PVOID pLowestUserAddress;

PVOID pMmHighestUserAddress;

ULONG uKeActiveProcessors;

BYTE bKeNumberProcessors;

BYTE bUnknown2;

WORD wUnknown3;

} SYSTEM_BASIC_INFORMATION;

typedef struct

{

LARGE_INTEGER liIdleTime;

DWORD dwSpare[76];

} SYSTEM_PERFORMANCE_INFORMATION;

typedef struct

{

LARGE_INTEGER liKeBootTime;

LARGE_INTEGER liKeSystemTime;

LARGE_INTEGER liExpTimeZoneBias;

ULONG uCurrentTimeZoneId;

DWORD dwReserved;

} SYSTEM_TIME_INFORMATION;

//变量定义

SYSTEM_PERFORMANCE_INFORMATION SysPerfInfo;

SYSTEM_TIME_INFORMATION SysTimeInfo;

SYSTEM_BASIC_INFORMATION SysBaseInfo;

double dbIdleTime;

double dbSystemTime;

LONG status;

LARGE_INTEGER liOldIdleTime;

LARGE_INTEGER liOldSystemTime;

PROCNTQSI NtQuerySystemInformation;

int m_nCpuUsage;

//定时

HWND m_hWnd;

int m_nRefreshInterval;//默认为1000毫秒

int m_nTimerID;

private:

static void CalcCpuUsage(HWND hwnd, UINT uMsg, UINT_PTR idEvent, DWORD dwTime);

int OnTimer();

};

inline CCpuUsage::CCpuUsage()

{

//

m_hWnd = NULL;

m_nRefreshInterval = 1000;

m_nTimerID = 1000;

m_nCpuUsage = 0;

//

memset(&liOldIdleTime , 0, sizeof(LARGE_INTEGER));

memset(&liOldSystemTime, 0, sizeof(LARGE_INTEGER));

//

NtQuerySystemInformation = (PROCNTQSI)GetProcAddress(

GetModuleHandle("ntdll") , "NtQuerySystemInformation");

if (!NtQuerySystemInformation)

return;

// get number of processors in the system

status = NtQuerySystemInformation(SystemBasicInformation,&SysBaseInfo,sizeof(SysBaseInfo),NULL);

if (status != NO_ERROR)

return;

// create control for timer

m_hWnd = ::CreateWindow("static", "", 0, 0, 0, 0, 0, NULL, NULL, 0, NULL);

::SetWindowLong(m_hWnd , GWL_USERDATA , (long)(this) );

TIMERPROC tp = (TIMERPROC)CalcCpuUsage;

SetTimer(m_hWnd , m_nTimerID, m_nRefreshInterval, tp);

}

inline CCpuUsage::~CCpuUsage()

{

KillTimer(m_hWnd , m_nTimerID);

DestroyWindow(m_hWnd);

}

inline void CCpuUsage::CalcCpuUsage(

HWND hwnd,

UINT uMsg,

UINT_PTR idEvent,

DWORD dwTime

)

{

CCpuUsage* pCpu = (CCpuUsage*)::GetWindowLong(hwnd , GWL_USERDATA);

if ( pCpu )

{

pCpu->OnTimer();

}

}

inline int CCpuUsage::OnTimer()

{

status = NtQuerySystemInformation(SystemTimeInformation,&SysTimeInfo,sizeof(SysTimeInfo),0);

if (status!=NO_ERROR)

return 0;

// get new CPU's idle time

status = NtQuerySystemInformation(SystemPerformanceInformation,&SysPerfInfo,sizeof(SysPerfInfo),NULL);

if (status != NO_ERROR)

return 0;

// if it's a first call - skip it

if (liOldIdleTime.QuadPart != 0)

{

// CurrentValue = NewValue - OldValue

dbIdleTime = Li2Double(SysPerfInfo.liIdleTime) - Li2Double(liOldIdleTime);

dbSystemTime = Li2Double(SysTimeInfo.liKeSystemTime) - Li2Double(liOldSystemTime);

// CurrentCpuIdle = IdleTime / SystemTime

dbIdleTime = dbIdleTime / dbSystemTime;

// CurrentCpuUsage% = 100 - (CurrentCpuIdle * 100) / NumberOfProcessors

dbIdleTime = 100.0 - dbIdleTime * 100.0 / (double)SysBaseInfo.bKeNumberProcessors + 0.5;

m_nCpuUsage = (UINT)dbIdleTime;

}

// store new CPU's idle and system time

liOldIdleTime = SysPerfInfo.liIdleTime;

liOldSystemTime = SysTimeInfo.liKeSystemTime;

// wait one second

return 0;

}

inline int CCpuUsage::GetCpuUsage()

{

return m_nCpuUsage;

}

inline int CCpuUsage::SetRefreshInterval(int milli_sec)

{

m_nRefreshInterval = milli_sec;

if ( m_hWnd )

{

TIMERPROC tp = (TIMERPROC)CalcCpuUsage;

SetTimer(m_hWnd, m_nTimerID, m_nRefreshInterval ,tp);

}

return 0;

}

(iwgh)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值