【Bug】 Access Violation exception&First-chance exception

本文详细介绍了在VC6调试环境中遇到的First-chance exception现象,解释了其含义,并强调在程序发布前应解决这类异常以确保程序稳定性。此外,还提到了Access Violation exception的处理,建议开发者对这类异常进行排查,以提高服务器的持续运行能力。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

###Date:2018-2-10

=====================================================================

转载自:http://blog.youkuaiyun.com/m_star_jy_sy/article/details/5578998

不要放过First-chance exception

1)什么是First-chance exception
 VC6调试环境下(debug)运行程序时,经常在output窗口看到有
 First-chance exception in hotfoxd.exe (KERNEL32.DLL): 0xE06D7363: Microsoft C++ Exception.
 的输出字样。
 当调试程序时,若引发了异常,那么调试器会得到通知,应用程序被挂起,由调试器决定如何来处理这个异常。而VC6调试器debug下对异常的默认处理为Stop if no handled,
 即异常未处理(捕获)时才停止。如果异常被程序捕获(try...catch...),那么调试器不会中断程序,而是继续运行,并在Output窗口输出First-chance exception字样。

2)怎么解决First-chance exception
 First-chance exception的输出表示程序产生了异常并被捕获了。对于异常在调试阶段应该尽可能解决掉,不让其出现异常。当然有些异常是预期的,有些异常是非预期的。
 例如,ado的查询语句,如果语句非法,则ado会报出异常。虽然有异常捕获,程序能继续运行,但这种错误明显的是需要解决的。 
 对于一个高可用服务器而言,要求7×24小时的连续运行,如果异常频繁出现,则会影响到服务器的持久运行能力。
 所以,在程序发布之前,过一遍First-chance exception是很有必要的。
 VC6能够修改调试器的默认行为(Stop if no handled),改为Stop always。通过[Debug/Exceptions]菜单。
 

这样,当出现异常时,即便是有异常捕获,也会弹出提示对话框,并停在异常代码处。

 改为Stop always后,查出几个供应包平台后台线程扫描数据库的几个sql语句不对的bug。这样的异常在后台线程频繁抛出,想必对服务器有些影响。
 

3)调试器还能对其他异常作出停止处理
 Stack Overflow exception
 Access Violation exception
 等。
 在程序发布前,建议对这些异常过一遍。

 

参考文献:

http://support.microsoft.com/kb/250563/en-us

http://blogs.msdn.com/davidklinems/archive/2005/07/12/438061.aspx




nt!DbgBreakPointWithStatus: fffff805`7affd0b0 cc int 3 kd> ed nt!Kd_DEFAULT_Mask 0xFFFFFFFF kd> ed nt!Kd_IHVDRIVER_Mask 0xFFFFFFFF kd> g [+] [ProcessNotifyCallback] 目标进程 oxygen.exe 创建 (PID: 8104) [+] [ProcessNotifyCallback] 工作线程已创建 [+] Worker thread started for hook installation [+] [InstallHook] 找到目标函数地址: FFFFF8057B2EFB60 [PTE_HOOK] 跳板池分配成功: 地址=0xFFFFCF812F1A9000, 大小=32768字节 [PTE_HOOK] 构造跳转指令: 目标地址: 0xFFFFF805802B15A0 跳板位置: 0xFFFFCF812F1A9000 指令格式: FF 25 00 00 00 00 + 8字节地址 [PTE_HOOK] 跳板指令: jmp [rip+0] -> 0xFFFFF805802B15A0 [PTE_HOOK] Hook记录 #0: 原始地址=0xFFFFF8057B2EFB60, 跳板=0xFFFFCF812F1A9000 [PTE_HOOK] Hook安装成功! 跳板指令: jmp [rip+0] -> 0xFFFFF805802B15A0 [+] [InstallHook] Hook 成功安装. 跳板地址: FFFFCF812F1A9000 Break instruction exception - code 80000003 (first chance) ******************************************************************************* * * * You are seeing this message because you pressed either * * CTRL+C (if you run console kernel debugger) or, * * CTRL+BREAK (if you run GUI kernel debugger), * * on your debugger machine's keyboard. * * * * THIS IS NOT A BUG OR A SYSTEM CRASH * * * * If you did not intend to break into the debugger, press the "g" key, then * * press the "Enter" key now. This message might immediately reappear. If it * * does, press "g" and "Enter" again. * * * ******************************************************************************* nt!DbgBreakPointWithStatus: fffff805`7affd0b0 cc int 3 kd> u FFFFCF812F1A9000 ffffcf81`2f1a9000 ff2500000000 jmp qword ptr [ffffcf81`2f1a9006] ffffcf81`2f1a9006 a0152b8005f8ffffff mov al,byte ptr [FFFFFFF805802B15h] ffffcf81`2f1a900f d5 ??? ffffcf81`2f1a9010 fd std ffffcf81`2f1a9011 5f pop rdi ffffcf81`2f1a9012 dd75f5 fnsave [rbp-0Bh] ffffcf81`2f1a9015 5d pop rbp ffffcf81`2f1a9016 7df7 jge ffffcf81`2f1a900f这个写入还没成功吗?什么原因
06-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值