高分请教关于计算机性能数据测试的问题

seekmore 2006-03-22 04:13:38
首先,我运行了一个程序(迅雷下载,为了够时间来测试,下了个msdn for vs.net 2003 :) ),打开控制面板-〉管理工具-〉性能,监控% process time,显示的平均值为6,最后值经常是3.125。
然后运行我得程序,发现有个现象,修改程序中的sleep(TIME),当TIME越小时,如10ms,100ms,程序测出来的数据比用工具测出来的数据普遍要大,而把TIME改到500ms时,终于也看到了3.125这样比较吻合的数据,请哪位大哥给我解释一下为什么会这样子?代码如下:
int CPDHInfo::GetPDHQuery(char *szObject,char *szInstance,char *szCounter)
{
HLOG phLog;
HQUERY hQuery;
HCOUNTER *pCounterHandle;
PDH_STATUS pdhStatus; //long int
DWORD ctrType,dwpcchBufferSize;
CHAR szPathBuffer[255] = {'\0'};
DWORD logType = PDH_LOG_TYPE_CSV;
//Open the query object.
try{
pdhStatus = PdhOpenQuery (0, 0, &hQuery);
if(pdhStatus!=ERROR_SUCCESS) throw -1;

pCounterHandle = (HCOUNTER *)GlobalAlloc(GPTR, sizeof(HCOUNTER));
if(pCounterHandle==NULL) throw -1;

if(strlen(szInstance)==0)
sprintf(szPathBuffer,"%c%s%c%s",BIAS_LEFT,szObject,BIAS_LEFT,szCounter);
else
sprintf(szPathBuffer,"%c%s%c%s%c%c%s",BIAS_LEFT,szObject,BRACKET_LEFT,szInstance,
BRACKET_RIGHT,BIAS_LEFT,szCounter);

pdhStatus = PdhAddCounter(hQuery,szPathBuffer,0,pCounterHandle);
if(pdhStatus!=ERROR_SUCCESS) throw -1;
#ifdef SYS_CREATE_PHDINFO_LOG_FILE
//vsn:1010 解决不能正确生成pdhinfo.log的问题
AnsiString sFilePath=ExtractFilePath(Application->ExeName);
AnsiString sFileName=sFilePath+szFileName;
if(!FileExists(sFileName))
FileCreate(sFileName);
#endif

// Open the log file for write access.
pdhStatus = PdhOpenLog(szFileName, PDH_LOG_WRITE_ACCESS | PDH_LOG_CREATE_ALWAYS ,
&logType, hQuery, 0, NULL, &phLog);

if(pdhStatus!=ERROR_SUCCESS) throw -1;

// Capture 10 samples and write them to the log.
for (int i= 0; i<10; i++) {
pdhStatus = PdhUpdateLog(phLog, TEXT("Some Text."));
if(pdhStatus!=ERROR_SUCCESS) throw -1;
Sleep(500); // Sleep for 1 seconds between samples
}
// Close the log and the Query

PdhCloseLog(phLog, PDH_FLAGS_CLOSE_QUERY);
}catch(...){
return -1;
}
return 0;
}
数据是10次采样写进Log里的。
...全文
60 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

6,211

社区成员

发帖
与我相关
我的任务
社区描述
windows网络管理与配置
社区管理员
  • 网络管理与配置社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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