作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在 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);
}
}
最佳答案
这不是一个真正的答案,而是一个建议。即使您只是查询注册表(而不是写入),我想知道您是否正在使用多线程产生某种死锁。
缺少 Windows 开发或测试环境,请采纳此建议的值(value):也许您可以在注册表调用周围使用互斥体...可以缓解任何死锁情况,如果这确实是问题。
祝你好运。
关于c++ - 连接到 64 位机器的 RegConnectRegistry 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2402557/
我正在开发一个 voip 调用应用程序。我需要做的是在接到来电时将 Activity 带到前台。我在应用程序中使用 Twilio,并在收到推送消息时开始调用。 问题是我试图在接到任何电话时显示 Act
我是一名优秀的程序员,十分优秀!