|
|
|
|
|
|
|
Windows内核调试
帖子发起人: xian 发起时间: 2009-12-27 16:06 下午 回复: 3
|
帖子排序:
|
|
|
|
2009-12-27, 16:06 下午
|
xian
注册: 2008-12-08
发 贴: 28
|
|
|
张老师各位高手:
最近一直遇到这样的问题,程序一运行抛出这样的异常(但不影响正常运行),这个异常一直没有搞清是什么原因引起的;这个问题着实让我苦闷呀,呵呵
该应用程序涉及第三方库(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。
|
|
|
IP 地址: 已记录
|
报告
|
|
|
|
2009-12-27, 16:24 下午
|
xian
注册: 2008-12-08
发 贴: 28
|
Re: 程序抛出net::NetException
|
|
|
|
张老师各位高手:
针对上面的问题,能不能给出一般的方法,解决这一类异常的方法,或者步骤
|
|
|
IP 地址: 已记录
|
报告
|
|
|
|
2009-12-28, 12:59 下午
|
格蠹老雷
注册: 2005-12-19
发 贴: 1,303
|
Re: 程序抛出net::NetException
|
|
|
|
要搞清这个问题,需要理解NT分发异常的过程;简单说会分两轮,每一轮会先给调试器。
从上面的信息来看,有代码抛出了C++异常(throw...),VS的集成调试器收到了,打印出消息,并告诉系统不处理这个异常,于是系统继续分发异常,分给程序中的异常处理函数(try{}catch()...),于是有代码处理了这个异常,程序仍然正常工作...
如果想知道是哪一段代码抛出了异常,那么只要配置调试器的异常处理策略,让它收到异常时中断下来;对于VS,也就是在Debug菜单中选Exceptions,弹出配置对话框...
这个异常分发过程对于软件开发和调试都非常重要,但是很遗憾,微软一直没有很好的描述这个过程;于是就连微软自己的很多工程师都糊里糊涂...
如果有《软件调试》,那么11、12章有非常详细的描述,第30章有配置异常处理方法(30.9节,事件处理)的讨论。
|
|
|
IP 地址: 已记录
|
报告
|
|
|
|
2009-12-28, 14:08 下午
|
xian
注册: 2008-12-08
发 贴: 28
|
Re: 程序抛出net::NetException
|
|
|
|
|
|
IP 地址: 已记录
|
报告
|
|
|
|
高端调试 » 软件调试 » Windows内核调试 » Re: 程序抛出net::NetException
|
|
|
|
|
|