Re: 程序抛出net::NetException

Windows内核调试

程序抛出net::NetException


xian 2009-12-27, 16:06 下午

张老师各位高手:

    最近一直遇到这样的问题,程序一运行抛出这样的异常(但不影响正常运行),这个异常一直没有搞清是什么原因引起的;这个问题着实让我苦闷呀,呵呵

该应用程序涉及第三方库(Intel(r) Amt SDK),其中下面7c800000是kernel32.dll的加载地址:

这是编译器中输出信息:
Generating RSA key pair...
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\rsaenh.dll”,未加载任何符号。
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\userenv.dll”,未加载任何符号。
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\netapi32.dll”,未加载任何符号。
RSA key pair generated successfully
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\mswsock.dll”,未加载任何符号。
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\hnetcfg.dll”,未加载任何符号。
“MFC-Test-2008.exe”: 已加载“C:\WINDOWS\system32\wshtcpip.dll”,未加载任何符号。
MFC-Test-2008.exe 中的 0x7c80bee7 处最可能的异常: Microsoft C++ 异常: 内存位置 0x0187ee94 处的 net::NetException。
MFC-Test-2008.exe 中的 0x7c80bee7 处最可能的异常: Microsoft C++ 异常: 内存位置 0x0187f1cc 处的 net::NetException。
MFC-Test-2008.exe 中的 0x7c80bee7 处最可能的异常: Microsoft C++ 异常: 内存位置 0x0187f464 处的 net::NetException。

Re: 程序抛出net::NetException


xian 2009-12-27, 16:24 下午
张老师各位高手:
针对上面的问题,能不能给出一般的方法,解决这一类异常的方法,或者步骤

Re: 程序抛出net::NetException


格蠹老雷 2009-12-28, 12:59 下午
要搞清这个问题,需要理解NT分发异常的过程;简单说会分两轮,每一轮会先给调试器。
从上面的信息来看,有代码抛出了C++异常(throw...),VS的集成调试器收到了,打印出消息,并告诉系统不处理这个异常,于是系统继续分发异常,分给程序中的异常处理函数(try{}catch()...),于是有代码处理了这个异常,程序仍然正常工作...

如果想知道是哪一段代码抛出了异常,那么只要配置调试器的异常处理策略,让它收到异常时中断下来;对于VS,也就是在Debug菜单中选Exceptions,弹出配置对话框...

这个异常分发过程对于软件开发和调试都非常重要,但是很遗憾,微软一直没有很好的描述这个过程;于是就连微软自己的很多工程师都糊里糊涂...
如果有《软件调试》,那么11、12章有非常详细的描述,第30章有配置异常处理方法(30.9节,事件处理)的讨论。

Re: 程序抛出net::NetException


xian 2009-12-28, 14:08 下午
谢谢

Powered by Community Server Powered by CnForums.Net