使用VB6和C ++ DLL在MSVBVM60.dll中访问冲突

时间:2010-12-14 10:04:29

标签: c++ winapi vb6 windbg application-verifier

我正在调查我正在处理的应用程序崩溃。 visual basic部分是一个简单的表单,它创建PictureBoxes和按钮。按下按钮后调用C + dll。 PictureBoxes提供DLL的句柄,使用它们来创建使用WINAPI的窗口并在OpenGL中显示。

最初在PictureBox中创建视图没问题,并且显示正确,但在重置事件时,视图将被销毁并重新创建。这是发生崩溃的时候。

我尝试了很多工具,应用程序验证程序,Windbg和调试诊断工具。 Windbg和Debug Diagnostic Tool都指向这个地方,但是我不知道如何修复它。

不幸的是,从VB6切换不是我的选择,因为它不受我的控制。

请点击崩溃日志的链接。

link text(允许发布1个链接,但两个日志都可见)

非常感谢任何帮助,

莱昂

1 个答案:

答案 0 :(得分:2)

从你的文本文件:

(134c.1344): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
eax=034b0ebc ebx=00000000 ecx=7352e100 edx=00000000 esi=02e6813c edi=02e6813c
eip=7349fdd2 esp=0012fc20 ebp=0012fc44 iopl=0         nv up ei pl nz na po nc
cs=001b  ss=0023  ds=0023  es=0023  fs=003b  gs=0000             efl=00010202
MSVBVM60!HrMenuHandleMenuCommand+0x3f:
7349fdd2 ffb048010000    push    dword ptr <Unloaded_Ed20.dll>+0x147 (00000148)[eax] ds:0023:034b1004=????????
0:000> kb
ChildEBP RetAddr  Args to Child              
0012fc28 7347e1b9 034b0ebc 00000000 02e92ee8 MSVBVM60!HrMenuHandleMenuCommand+0x3f
0012fc44 7347dc27 034b0ebc 000f144a 00000111 MSVBVM60!_DefWmCommand+0xc7
0012fcb0 734d378a 02e92ee8 000f144a 00000111 MSVBVM60!VBDefControlProc+0xb47
0012fcf0 7347ce03 034b0ebc 000f144a 00000111 MSVBVM60!PixCtlProc+0x57c
0012fd18 7347f800 034b0ebc 000f144a 00000111 MSVBVM60!CommonGizWndProc+0xae
0012fd74 7e418734 000f144a 00000111 00000000 MSVBVM60!StdCtlWndProc+0x232
0012fda0 7e418816 7347f5d1 000f144a 00000111 USER32!InternalCallWinProc+0x28
0012fe08 7e4189cd 00000000 7347f5d1 000f144a USER32!UserCallWinProcCheckWow+0x150
0012fe68 7e4196c7 0012fe90 00000001 0012feb8 USER32!DispatchMessageWorker+0x306
0012fe78 7342a6b0 0012fe90 ffffffff 02e76fec USER32!DispatchMessageA+0xf
0012feb8 7342a627 ffffffff 02e78f8c 02e60000 MSVBVM60!ThunderMsgLoop+0xfd
0012fecc 7342a5c9 02e76fec ffffffff 02e7efcc MSVBVM60!CMsoCMHandler::FPushMessageLoop+0x19
0012fefc 7342a505 02e7efcc ffffffff 0000134c MSVBVM60!SCM::FPushMessageLoop+0xb9
0012ff18 7342a4d0 02e78f88 02e7efcc ffffffff MSVBVM60!SCM_MsoCompMgr::FPushMessageLoop+0x2b
0012ff3c 73423644 ffffffff 0183f558 0078c2bc MSVBVM60!CMsoComponent::PushMsgLoop+0x26
0012ffb8 004013aa 00401ac4 7c817077 0183f558 MSVBVM60!ThunRTMain+0x9b
0012fff0 00000000 004013a0 00000000 78746341 with_debug_info!__vbaS+0xa

你在:MSVBVM60!HrMenuHandleMenuCommand + 0x3f

fialed指令:push dword ptr + 0x147(00000148)[eax] ds:0023:034b1004 = ????????

eax无效,因此derefernce失败。

我的猜测是你在Ed20.dll中有一个菜单处理程序正在尝试运行,但是这个dll已被卸载(如<Unloaded_Ed20.dll>所示)。您应该找出为什么1.卸载了dll或2.为什么在卸载后仍然会注册处理程序。