私は、32ビットMFCVC2010アプリケーション内で発生している散発的な本番環境の問題に取り組んでいます。アプリケーションは、Windows Server 2008 R2 StandardSP164ビットで実行されています。
この問題は、CWnd派生クラスの作成に失敗したことが原因で発生します。失敗が発生すると、AfxUnhookWindowCreateメソッドはCWnd::CreateEx内でfalseを返します。これは、pThreadState->m_pWndInit変数がNULLではないためです。HCBT_CREATEWNDがフックされている場合、_AfxCbtFilterHookはこれをNULLに設定する必要があるようですが、これは発生していないようです。CREATESTRUCTからログアウトし、障害が発生した場合と発生しなかった場合を比較しました。パラメーターは基本的に同じです。
誰かがこれを引き起こす可能性があるもの、または私が原因を特定する方法についてのアイデアを持っていますか?ありがとう!
BOOL CWnd::CreateEx(DWORD dwExStyle, LPCTSTR lpszClassName,
LPCTSTR lpszWindowName, DWORD dwStyle,
int x, int y, int nWidth, int nHeight,
HWND hWndParent, HMENU nIDorHMenu, LPVOID lpParam)
{
...
if (!PreCreateWindow(cs))
{
PostNcDestroy();
return FALSE;
}
AfxHookWindowCreate(this);
HWND hWnd = ::AfxCtxCreateWindowEx(cs.dwExStyle, cs.lpszClass,
cs.lpszName, cs.style, cs.x, cs.y, cs.cx, cs.cy,
cs.hwndParent, cs.hMenu, cs.hInstance, cs.lpCreateParams);
...
if (!AfxUnhookWindowCreate())
PostNcDestroy(); // cleanup if CreateWindowEx fails too soon
...
BOOL AFXAPI AfxUnhookWindowCreate()
{
_AFX_THREAD_STATE* pThreadState = _afxThreadState.GetData();
#ifndef _AFXDLL
if (afxContextIsDLL && pThreadState->m_hHookOldCbtFilter != NULL)
{
::UnhookWindowsHookEx(pThreadState->m_hHookOldCbtFilter);
pThreadState->m_hHookOldCbtFilter = NULL;
}
#endif
if (pThreadState->m_pWndInit != NULL)
{
pThreadState->m_pWndInit = NULL;
return FALSE; // was not successfully hooked
}
return TRUE;
}
LRESULT CALLBACK
_AfxCbtFilterHook(int code, WPARAM wParam, LPARAM lParam)
{
_AFX_THREAD_STATE* pThreadState = _afxThreadState.GetData();
if (code != HCBT_CREATEWND)
{
// wait for HCBT_CREATEWND just pass others on...
return CallNextHookEx(pThreadState->m_hHookOldCbtFilter, code,
wParam, lParam);
}
...
pThreadState->m_pWndInit = NULL;