在 64 位版本的 Windows 上连接到性能注册表时,我看到了一件奇怪的事情。整个程序停顿,调用堆栈变得不可读。长时间超时后,连接尝试中止,一切恢复正常。
唯一的解决方案是确保每次只有一个线程查询远程注册表,除非远程机器是 32 位 Windows XP, 2003, 2000 ,那么您可以使用任意数量的线程。
有没有人解释为什么会发生这种情况?我花了 2-3 天在网上搜索,但没有提出任何建议。
这是一个测试程序,先用一个线程运行(连接到64位Windows),然后去掉tmain中的注释,用4个线程运行。使用一个线程运行它可以按预期运行,使用 4 运行,在停止一段时间后返回 ERROR_BUSY (dwRet == 170)。
请记住在运行程序之前在 RegConnectRegistry 中正确设置远程计算机。
#define TOTALBYTES 8192
#define BYTEINCREMENT 4096
void PerfmonThread(void *pData)
{
DWORD BufferSize = TOTALBYTES;
DWORD cbData;
DWORD dwRet;
PPERF_DATA_BLOCK PerfData = (PPERF_DATA_BLOCK) malloc( BufferSize );
cbData = BufferSize;
printf("\nRetrieving the data...");
HKEY hKey;
DWORD dwAccessRet = RegConnectRegistry(L"REMOTE_MACHINE",HKEY_PERFORMANCE_DATA,&hKey);
dwRet = RegQueryValueEx( hKey,L"global",NULL,NULL,(LPBYTE) PerfData, &cbData );
while( dwRet == ERROR_MORE_DATA )
{
// Get a buffer that is big enough.
BufferSize += BYTEINCREMENT;
PerfData = (PPERF_DATA_BLOCK) realloc( PerfData, BufferSize );
cbData = BufferSize;
printf(".");
dwRet = RegQueryValueEx( hKey,L"global",NULL,NULL,(LPBYTE) PerfData,&cbData );
}
if( dwRet == ERROR_SUCCESS )
printf("\n\nFinal buffer size is %d\n", BufferSize);
else
printf("\nRegQueryValueEx failed (%d)\n", dwRet);
RegCloseKey(hKey);
}
int _tmain(int argc, _TCHAR* argv[])
{
_beginthread(PerfmonThread,0,NULL);
/* _beginthread(PerfmonThread,0,NULL);
_beginthread(PerfmonThread,0,NULL);
_beginthread(PerfmonThread,0,NULL);
*/
while(1)
{
Sleep(2000);
}
}