理解UnhandledExceptionFilter

 最初发表在QQ空间,全文参见 理解UnhandledExceptionFilter

UnhandledExceptionFilter,在一个windows平台上的C/C++程序中,主线程的SEH框架会有2层,最外层是BaseProcessStart,里面是mainCRTStartup,这意味着一般情况下,当有异常发生时,UnhandledExceptionFilter会被调用2次。安静

UEF首先会检测当前进程的DebugPort,如果存在,则返回EXCEPTION_CONTINUE_SEARCH,继续分发异常。这也是为什么,只有在调试情况下,用户态异常才有第2轮分发的机会。

下面,UEF会调用_BasepCurrentTopLevelFilter(如果存在),这个值是用SetUnhandledExceptionFilter设定的。参见 Windows平台下的异常处理

然后,UEF中会检测是否显示GPF,如果不显示,则UEF返回EXCEPTION_EXECUTE_HANDLER,通常也就是终止进程。

UEF接下来会显示Error Box,要么用户选择关闭进程,也还是如上面一样,UEF返回EXCEPTION_EXECUTE_HANDLER,终止进程,要么用户就启用了JIT,UEF返回EXCEPTION_CONTINUE_SEARCH,这样才会有调用外层UEF的机会。

在第一次的UEF调用中,如果启用了JIT,则由于NtDebugActiveProcess函数的作用,当前的进程已经成为了一个被调试的进程,所以第2次的UEF调用中检测到当前进程是一个被调试的进程,直接返回了EXCEPTION_CONTINUE_SEARCH,这样也导致了第2轮的异常分发,调试器会首先收到这一异常。惊恐

从上面的流程可以看出,用户自定义的未处理异常过滤器即顶层异常过滤器被调用的条件是2个,1. 发生未处理的异常 2. 当前进程不在被调试

2011/05/04:

补充一个意外的发现,__report_gsfailure中UEF的特殊行为

 

 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值