媽咪媽咪哄~~~~神仙妖怪請進來~~﹗﹗

zard_daba 2005-11-05 10:19:20
下面是俺好不容易在網上找到的一段使用VC取CPU使用率的代碼﹐只怪俺不學無數不會改
請各位神仙﹑妖怪幫俺一下。
要求﹕把CPU使用率和當時系統時間作為兩個字段存入SQLSERVER中
酬禮100分. 謝謝

-------=======================我是分割線=================================================
// cpusagent.cpp (Windows NT/2000)
//
// Getting the CPU usage in percent on Windows NT/2000
//
// (c)2000 Ashot Oganesyan K, SmartLine, Inc
// mailto:ashot@aha.ru, http://www.protect-me.com, http://www.codepile.com

#include <windows.h>
#include <conio.h>
#include <stdio.h>

#define SystemBasicInformation 0
#define SystemPerformanceInformation 2
#define SystemTimeInformation 3

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

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;


// ntdll!NtQuerySystemInformation (NT specific!)
//
// The function copies the system information of the
// specified type into a buffer
//
// NTSYSAPI
// NTSTATUS
// NTAPI
// NtQuerySystemInformation(
// IN UINT SystemInformationClass, // information type
// OUT PVOID SystemInformation, // pointer to buffer
// IN ULONG SystemInformationLength, // buffer size in bytes
// OUT PULONG ReturnLength OPTIONAL // pointer to a 32-bit
// // variable that receives
// // the number of bytes
// // written to the buffer
// );
typedef LONG (WINAPI *PROCNTQSI)(UINT,PVOID,ULONG,PULONG);

PROCNTQSI NtQuerySystemInformation;


void main(void)
{
SYSTEM_PERFORMANCE_INFORMATION SysPerfInfo;
SYSTEM_TIME_INFORMATION SysTimeInfo;
SYSTEM_BASIC_INFORMATION SysBaseInfo;
double dbIdleTime;
double dbSystemTime;
LONG status;
LARGE_INTEGER liOldIdleTime = {0,0};
LARGE_INTEGER liOldSystemTime = {0,0};

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;

printf("\nCPU Usage (press any key to exit): ");
while(!_kbhit())
{
// get new system time
status = NtQuerySystemInformation(SystemTimeInformation,&SysTimeInfo,sizeof(SysTimeInfo),0);
if (status!=NO_ERROR)
return;

// get new CPU's idle time
status = NtQuerySystemInformation(SystemPerformanceInformation,&SysPerfInfo,sizeof(SysPerfInfo),NULL);
if (status != NO_ERROR)
return;

// 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;

printf("\b\b\b\b%3d%%",(UINT)dbIdleTime);

}

// store new CPU's idle and system time
liOldIdleTime = SysPerfInfo.liIdleTime;
liOldSystemTime = SysTimeInfo.liKeSystemTime;

// wait one second
Sleep(1000);
}
printf("\n");
}
...全文
269 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
蒋晟 2005-11-17
  • 打赏
  • 举报
回复
http://msdn.microsoft.com/library/en-us/adosql/adoprg01_1kwv.asp
lsqkeke 2005-11-15
  • 打赏
  • 举报
回复
顶就一个字 !
wos 2005-11-15
  • 打赏
  • 举报
回复
玛丽玛丽红
cshmai 2005-11-12
  • 打赏
  • 举报
回复
不会
honhaizh 2005-11-12
  • 打赏
  • 举报
回复
zhaihui 2005-11-12
  • 打赏
  • 举报
回复
yaoguai............
max415 2005-11-10
  • 打赏
  • 举报
回复
单独的插入调用SQL的程序,不是很难啊,msdn就能帮你解决!

kugou123 2005-11-10
  • 打赏
  • 举报
回复
获取使用率,然后获取当前时间,插入数据库,挺简单的。
ravehe 2005-11-10
  • 打赏
  • 举报
回复
可惜诛仙剑已断.....
bboonnee 2005-11-09
  • 打赏
  • 举报
回复
媽咪媽咪哄~~~~不是妖怪不是神仙,顶你一下~~﹗﹗
zard_daba 2005-11-08
  • 打赏
  • 举报
回复

zard_daba 2005-11-05
  • 打赏
  • 举报
回复
妖怪~~
zard_daba 2005-11-05
  • 打赏
  • 举报
回复
頂起﹐~~神仙姐姐在那里?
兔子-顾问 2005-11-05
  • 打赏
  • 举报
回复
布下诛仙大阵了。。。
ycc2008 2005-11-05
  • 打赏
  • 举报
回复
媽咪媽咪哄~~~~不是妖怪不是神仙,稍稍顶你一下~~﹗﹗
cansum396 2005-11-05
  • 打赏
  • 举报
回复
不会
oyljerry 2005-11-05
  • 打赏
  • 举报
回复
通过sql语句等存入数据库啊

7,539

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 VC.NET
社区管理员
  • VC.NET社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧