微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c – WndProc中的64位异常无声地失败

Windows 7 32位下运行时,以下代码将导致硬故障:
void CTestView::OnDraw(CDC* /*pDC*/)
{
    *(int*)0 = 0; // Crash

    CTestDoc* pDoc = GetDocument();
    ASSERT_VALID(pDoc);
    if (!pDoc)
        return;

    // Todo: add draw code for native data here
}

但是,如果我在Windows 7 64bit上尝试这个,我只是在输出窗口中得到它:

First-chance exception at 0x13929384
in Test.exe: 0xC0000005: Access
violation writing location 0x00000000.
First-chance exception at 0x77c6ee42
in Test.exe: 0xC0150010: The
activation context being deactivated
is not active for the current thread
of execution.

这是什么原因?我知道这是一个硬件异常(http://msdn.microsoft.com/en-us/library/aa363082.aspx),但为什么在32位和64位下运行的差异?我该怎么做才能正确处理这类错误?因为它们应该被捕获和修复,而不是目前正在发生的事情,Windows只是继续向应用程序发送消息并让它运行(因此用户和开发人员完全没有意识到实际发生了任何问题).

更新:
我们的常规崩溃报告软件使用SetUnhandledExceptionFilter但不会在x64上调用WndProc中的硬件异常.有没有人有关于此的任何信息,或解决方法

UPDATE2:
我在Microsoft Connect上报告了这个问题:
https://connect.microsoft.com/VisualStudio/feedback/details/550944/hardware-exceptions-on-x64-machines-are-silently-caught-in-wndproc-messages

解决方法

在针对访问冲突异常展开堆栈时会引发另一个异常.被吞噬,导致AV消失.您需要找出正在执行此操作的代码.调试异常,检查Win32异常的Thrown框.调试器将在第一个停止,继续.当它再次停止时检查调用堆栈.如果您无法弄明白,请将其添加到您的问题中.

原文地址:https://www.jb51.cc/c/118799.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐