我有一个我一直试图启动并运行的旧版应用程序。

它与只能在WinXP(或更早版本)上安装的DirectX SDK旧版本有一些依赖性,因此我使用了我的虚拟机并成功构建了该应用程序。但是,由于虚拟图形硬件的限制,该应用程序无法正确呈现其图形,但这只是预期的。应用程序的其余部分(UI交互等)似乎在虚拟机(32位Windows XP)上可以正常工作。

当我尝试在物理计算机(64位Windows 7)上运行应用程序时,它处于早期状态。我使用了一些调试输出来精确地跟踪它的挂起位置,也就是在调用CDialog :: Create来创建无模式对话框时。

我终于尝试在我的笔记本电脑(32位Windows 8.1)上启动它,并且可以正常工作。我认为它应该与x86和x64有关,但是我不确定。

有人碰过类似的东西吗?我在CDialog :: Create Hanging上进行了很多搜索,发现了一些有趣的线程,但是所有代码看起来都正确,并且可以运行,但只能在32位计算机上运行。

更新:

我设法通过删除一堆代码在VS2010中构建了该应用程序。当我调试应用程序时,调用堆栈显示它挂在CWnd :: CreateDlgIndirect的CreateDialogIndirect调用上。

我找到了a thread regarding this,但它没有解决任何问题,正在调用AfxOleInit。

This discussion听起来更有趣,但是我还没有去尝试提议的解决方案。

更新2:

将DEP设置为AlwaysOff不会更改任何内容。

完整的调用堆栈如下所示:

ntdll.dll!_NtDelayExecution@8()  + 0x15 bytes
ntdll.dll!_NtDelayExecution@8()  + 0x15 bytes
KernelBase.dll!_Sleep@4()  + 0xf bytes
nvoglv32.dll!6955244d()
[Frames below may be incorrect and/or missing, no symbols loaded for nvoglv32.dll]
nvoglv32.dll!68e3e2e7()
nvoglv32.dll!6954d2ad()
nvoglv32.dll!6954d37c()
user32.dll!_DispatchHookA@16()  + 0x56 bytes
user32.dll!_fnHkINLPCWPSTRUCTA@24()  + 0x66 bytes
user32.dll!___fnINLPCREATESTRUCT@4()  + 0x68 bytes
ntdll.dll!_KiUserCallbackDispatcher@12()  + 0x2e bytes
user32.dll!_NtUserCreateWindowEx@60()  + 0x15 bytes
user32.dll!_VerNtUserCreateWindowEx@52()  + 0x18a bytes
user32.dll!_InternalCreateDialog@28()  + 0x42a bytes
user32.dll!_CreateDialogIndirectParamAorW@24()  + 0x33 bytes
user32.dll!_CreateDialogIndirectParamA@20()  + 0x1b bytes
Viewer.exe!CWnd::CreateDlgIndirect(const DLGTEMPLATE * lpDialogTemplate, CWnd * pParentWnd, HINSTANCE__ * hInst)  Line 370  C++
Viewer.exe!CDialog::CreateIndirect(const DLGTEMPLATE * lpDialogTemplate, CWnd * pParentWnd, void * lpDialogInit, HINSTANCE__ * hInst)  Line 262 + 0x17 bytes    C++
Viewer.exe!CDialog::CreateIndirect(void * hDialogTemplate, CWnd * pParentWnd, HINSTANCE__ * hInst)  Line 240 + 0x10 bytes   C++
Viewer.exe!CDialog::Create(const char * lpszTemplateName, CWnd * pParentWnd)  Line 223  C++
Viewer.exe!CToolDialog::CreateModeless(CWnd * pParent)  Line 41
Viewer.exe!CMainFrame::CreateTools()  Line 176 + 0x17 bytes C++
Viewer.exe!CViewerApp::OnIdle(long lCount)  Line 1293   C++
Viewer.exe!CWinThread::Run()  Line 621 + 0xa bytes  C++
Viewer.exe!AfxWinMain(HINSTANCE__ * hInstance, HINSTANCE__ * hPrevInstance, char * lpCmdLine, int nCmdShow)  Line 47 + 0x7 bytes    C++
Viewer.exe!__tmainCRTStartup()  Line 275 + 0x1c bytes   C
kernel32.dll!@BaseThreadInitThunk@12()  + 0x12 bytes
ntdll.dll!___RtlUserThreadStart@8()  + 0x27 bytes
ntdll.dll!__RtlUserThreadStart@8()  + 0x1b bytes


更新3

通常使用C#启动器应用程序启动该应用程序(以便能够选择用户配置文件和其他启动设置),并以这种方式将其挂起。另外,从文件资源管理器(或命令提示符)启动它会挂起。但是,如果我直接使用F5从VS2010启动它,它将运行...

解决了

我更新了图形驱动程序,一切正常。

最佳答案

我更新了图形驱动程序,一切正常。

关于c++ - MFC CDialog::Create卡在x64上,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21797453/

10-12 19:23