CLR Exception 0xE0434F4D和0xE0434352的区别
《根据《CLR Exception---E0434352》和《CLR Exception---E0434F4D》这两篇随笔,我们会发现,这两个异常太相似了,除了代码值不一样,其他几乎都一样。在windbg里调试dmp时,也会看到都叫它们CLR Exception。那他们有什么区别呢?这个问题值得研究研究。
我查了很多资料都没查明白。但是黄天不负有心人。在我搞其他问题时,让我窥得一线道道儿来。
首先上个实际的例子,在VS2013里新建一个c#控制台工程ConsoleApplication1,代码如下:
static void Main(string[] args)
{
throw new System.Exception();
return;
}
工程配置如下:
编译好后,用Windbg加载运行
输入g运行,接着会抛出异常中断
我们可以看到
此时抛出的异常是CLR exception---code e0434352
输入kv,观察下栈
0:000> kv
# ChildEBP RetAddr Args to Child
00 00bcf214 7234ea5c e0434352 00000001 00000005 KERNELBASE!RaiseException+0x62 (FPO: [4,22,0])
01 00bcf2b0 7234f626 00000000 a4329156 00bcf3a0 clr!RaiseTheExceptionInternalOnly+0x230 (FPO: [SEH])
02 00bcf378 07550882 076023ac 076023a0 00bcf394 clr!IL_Throw+0x146 (FPO: [Non-Fpo])
WARNING: Frame IP not in any known module. Following frames may be wrong.
03 00bcf388 721af066 010184c0 00bcf3e8 721b2375 0x7550882
04 00bcf394 721b2375 00bcf430 00bcf3d8 7234e800 clr!CallDescrWorkerInternal+0x34
05 00bcf3e8 721bb3f5 00000000 076023a0 00bcf444 clr!CallDescrWorkerWithHandler+0x6b (FPO: [Non-Fpo])
06 00bcf45c 722c6d3f 00bcf538 a43297ae 071d4d5c clr!MethodDescCallSite::CallTargetWorker+0x16a (FPO: [Non-Fpo])
07 00bcf580 722c741a 00bcf5c4 00000000 a43295c2 clr!RunMain+0x1b3 (FPO: [Non-Fpo])
08 00bcf7ec 722c7347 00000000 a4329efe 00a30000 clr!Assembly::ExecuteMainMethod+0xf7 (FPO: [Non-Fpo])
09 00bcfcd0 722c74c8 a4329f06 00000000 00000000 clr!SystemDomain::ExecuteMainMethod+0x5ef (FPO: [Non-Fpo])
0a 00bcfd28 722c75ee a4329f46 00000000 723117c0 clr!ExecuteEXE+0x4c (FPO: [Non-Fpo])
0b 00bcfd68 723117e5 a4329f8a 00000000 723117c0 clr!_CorExeMainInternal+0xdc (FPO: [Non-Fpo])
0c 00bcfda4 7295fa84 047a2010 729f43f0 7295fa20 clr!_CorExeMain+0x4d (FPO: [Non-Fpo])
0d 00bcfddc 729ee80e 729f43f0 72950000 00bcfe04 mscoreei!_CorExeMain+0xd6 (FPO: [Non-Fpo])
0e 00bcfdec 729f43f8 729f43f0 74c00419 00db6000 MSCOREE!ShellShim__CorExeMain+0x9e (FPO: [Non-Fpo])
0f 00bcfdf4 74c00419 00db6000 74c00400 00bcfe60 MSCOREE!_CorExeMain_Exported+0x8 (FPO: [0,0,4])
10 00bcfe04 76f2662d 00db6000 ba7d08ea 00000000 KERNEL32!BaseThreadInitThunk+0x19 (FPO: [Non-Fpo])
11 00bcfe60 76f265fd ffffffff 76f451e3 00000000 ntdll!__RtlUserThreadStart+0x2f (FPO: [SEH])
12 00bcfe70 00000000 729f43f0 00db6000 00000000 ntdll!_RtlUserThreadStart+0x1b (FPO: [Non-Fpo])
可以看到,当我们的代码throw异常时,调用了clr!IL_Throw--->clr!RaiseTheExceptionInternalOnly--->KERNELBASE!RaiseException
输入 uf clr!RaiseTheExceptionInternalOnly观察下RaiseException的调用过程和参数传递
0:000> uf clr!RaiseTheExceptionInternalOnly
...
7234e9f4 c785bcffffff524343e0 mov dword ptr [ebp-44h],0E0434352h
clr!RaiseTheExceptionInternalOnly+0x19c:
7234e9fe 8b85e0ffffff mov eax,dword ptr [ebp-20h]
7234ea04 8b4004 mov eax,dword ptr [eax+4]
7234ea07 a900000010 test eax,10000000h
7234ea0c 0f8556931600 jne clr!RaiseTheExceptionInternalOnly+0x1a9 (724b7d68) Branch
clr!RaiseTheExceptionInternalOnly+0x1db:
7234ea12 8d95c4ffffff lea edx,[ebp-3Ch]
7234ea18 6a3e push 3Eh
7234ea1a 59 pop ecx
7234ea1b e873feffff call clr!IsExceptionOfType (7234e893)
7234ea20 85c0 test eax,eax
7234ea22 0f858b931600 jne clr!RaiseTheExceptionInternalOnly+0x1ef (724b7db3) Branch
clr!RaiseTheExceptionInternalOnly+0x1ea:
7234ea28 3985c8ffffff cmp dword ptr [ebp-38h],eax
7234ea2e 0f857f931600 jne clr!RaiseTheExceptionInternalOnly+0x1ef (724b7db3) Branch
clr!RaiseTheExceptionInternalOnly+0x1fb:
7234ea34 803d34208e7200 cmp byte ptr [clr!g_StackProbingEnabled (728e2034)],0
7234ea3b 0f8586931600 jne clr!RaiseTheExceptionInternalOnly+0x204 (724b7dc7) Branch
clr!RaiseTheExceptionInternalOnly+0x218:
7234ea41 6a01 push 1
7234ea43 8d8d8cffffff lea ecx,[ebp-74h]
7234ea49 e8e736e6ff call clr!GCPreempNoDtor::Enter (721b2135)
7234ea4e 56 push esi
7234ea4f 53 push ebx
7234ea50 57 push edi
7234ea51 ffb5bcffffff push dword ptr [ebp-44h]
7234ea57 ff15e4628f72 call dword ptr [clr!_imp__RaiseException (728f62e4)]
...
可以看到clr!RaiseTheExceptionInternalOnly函数传给RaiseException的参数确实是0xE0434352。
现在,我们修改下工程配置,将Framework版本改为3.5,如下
然后编译,在Windbg加载运行,最后程序抛出异常中断
可以看到此时抛出了CLR exception---code e0434f4d
输入kv,看下栈
0:000> kv
# ChildEBP RetAddr Args to Child
00 006feb3c 791f7e04 e0434f4d 00000001 00000001 KERNELBASE!RaiseException+0x62 (FPO: [4,22,0])
01 006feb9c 792595d0 06d02cb0 00000000 00000000 mscorwks!RaiseTheExceptionInternalOnly+0x2a8 (FPO: [Non-Fpo])
02 006fec60 08fc00a5 06d02cb0 06d02ca0 006fec80 mscorwks!JIT_Throw+0xfc (FPO: [Non-Fpo])
WARNING: Frame IP not in any known module. Following frames may be wrong.
03 006fec70 79181b6c 00000003 006fec84 006fed00 0x8fc00a5
04 006fec80 79198603 006fed50 00000000 006fed20 mscorwks!CallDescrWorker+0x33
05 006fed00 791a06a3 006fed50 00000000 006fed20 mscorwks!CallDescrWorkerWithHandler+0xa3 (FPO: [Non-Fpo])
06 006fee40 791a06d6 06abc030 006fef0c 006feed8 mscorwks!MethodDesc::CallDescr+0x19c (FPO: [Non-Fpo])
07 006fee5c 791a06f4 06abc030 006fef0c 006feed8 mscorwks!MethodDesc::CallTargetWorker+0x1f (FPO: [Non-Fpo])
08 006fee74 7926090d 006feed8 1c0b468b 00000000 mscorwks!MethodDescCallSite::Call_RetArgSlot+0x1a (FPO: [Non-Fpo])
09 006fefd8 7926082d 06ab301c 00000001 006ff014 mscorwks!ClassLoader::RunMain+0x223 (FPO: [Non-Fpo])
0a 006ff240 79260d4a 00000000 1c0b5e43 00000001 mscorwks!Assembly::ExecuteMainMethod+0xa6 (FPO: [Non-Fpo])
0b 006ff710 79260f34 002f0000 00000000 1c0b5e33 mscorwks!SystemDomain::ExecuteMainMethod+0x45e (FPO: [Non-Fpo])
0c 006ff760 79260e64 002f0000 1c0b5efb 00000000 mscorwks!ExecuteEXE+0x59 (FPO: [Non-Fpo])
0d 006ff7a8 7295fa84 4635529f 729f43f0 7295fa20 mscorwks!_CorExeMain+0x15c (FPO: [Non-Fpo])
0e 006ff7e0 729ee80e 729f43f0 72950000 006ff808 mscoreei!_CorExeMain+0xd6 (FPO: [Non-Fpo])
0f 006ff7f0 729f43f8 729f43f0 74c00419 00438000 MSCOREE!ShellShim__CorExeMain+0x9e (FPO: [Non-Fpo])
10 006ff7f8 74c00419 00438000 74c00400 006ff864 MSCOREE!_CorExeMain_Exported+0x8 (FPO: [0,0,4])
11 006ff808 76f2662d 00438000 589054b8 00000000 KERNEL32!BaseThreadInitThunk+0x19 (FPO: [Non-Fpo])
12 006ff864 76f265fd ffffffff 76f451d5 00000000 ntdll!__RtlUserThreadStart+0x2f (FPO: [SEH])
13 006ff874 00000000 729f43f0 00438000 00000000 ntdll!_RtlUserThreadStart+0x1b (FPO: [Non-Fpo])
可以看到,当我们的代码throw异常时,调用了mscorwks!JIT_Throw-->mscorwks!RaiseTheExceptionInternalOnly--->KERNELBASE!RaiseException
输入 uf mscorwks!RaiseTheExceptionInternalOnly观察下RaiseException的调用过程和参数传递
0:000> uf mscorwks!RaiseTheExceptionInternalOnly
...
791f7d7c bb4d4f43e0 mov ebx,0E0434F4Dh
mscorwks!RaiseTheExceptionInternalOnly+0x1db:
791f7d81 8b4704 mov eax,dword ptr [edi+4]
791f7d84 a900000010 test eax,10000000h
791f7d89 7425 je mscorwks!RaiseTheExceptionInternalOnly+0x210 (791f7db0) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x1e5:
791f7d8b 8d4508 lea eax,[ebp+8]
791f7d8e 50 push eax
791f7d8f 6a43 push 43h
791f7d91 e8c5feffff call mscorwks!IsExceptionOfType (791f7c5b)
791f7d96 85c0 test eax,eax
791f7d98 7416 je mscorwks!RaiseTheExceptionInternalOnly+0x210 (791f7db0) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x1f4:
791f7d9a 81677cfff7ffff and dword ptr [edi+7Ch],0FFFFF7FFh
791f7da1 8b470c mov eax,dword ptr [edi+0Ch]
791f7da4 8945cc mov dword ptr [ebp-34h],eax
791f7da7 83f8ff cmp eax,0FFFFFFFFh
791f7daa 0f8476851d00 je mscorwks!RaiseTheExceptionInternalOnly+0x206 (793d0326) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x210:
791f7db0 8d4508 lea eax,[ebp+8]
791f7db3 50 push eax
791f7db4 6a3d push 3Dh
791f7db6 e8a0feffff call mscorwks!IsExceptionOfType (791f7c5b)
791f7dbb 85c0 test eax,eax
791f7dbd 0f8572851d00 jne mscorwks!RaiseTheExceptionInternalOnly+0x224 (793d0335) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x21f:
791f7dc3 394510 cmp dword ptr [ebp+10h],eax
791f7dc6 0f8569851d00 jne mscorwks!RaiseTheExceptionInternalOnly+0x224 (793d0335) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x232:
791f7dcc 897dd4 mov dword ptr [ebp-2Ch],edi
791f7dcf 8d45d4 lea eax,[ebp-2Ch]
791f7dd2 2d00c00000 sub eax,0C000h
791f7dd7 8b8ff4010000 mov ecx,dword ptr [edi+1F4h]
791f7ddd 894dc8 mov dword ptr [ebp-38h],ecx
791f7de0 3bc1 cmp eax,ecx
791f7de2 0f8260851d00 jb mscorwks!RaiseTheExceptionInternalOnly+0x24a (793d0348) Branch
mscorwks!RaiseTheExceptionInternalOnly+0x26b:
791f7de8 c745d001000000 mov dword ptr [ebp-30h],1
mscorwks!RaiseTheExceptionInternalOnly+0x254:
791f7def 8bcf mov ecx,edi
791f7df1 e80f20f9ff call mscorwks!Thread::EnablePreemptiveGC (79189e05)
791f7df6 56 push esi
791f7df7 ff75e4 push dword ptr [ebp-1Ch]
791f7dfa ff75e0 push dword ptr [ebp-20h]
791f7dfd 53 push ebx
791f7dfe ff1554121879 call dword ptr [mscorwks!_imp__RaiseException (79181254)]
...
可以看到mscorwks!RaiseTheExceptionInternalOnly函数传给RaiseException的参数确实是0xE0434F4D。
通过这两个对比,我们可以发现视乎CLR异常跟.net Framework版本有关,我又做了.net Framework 3.0/2.0,发现CLR异常是0xE0434F4D,而.net Framework 4.0/4.6/4.7/4.8版本的CLR异常是0xE0434352,同时我们发现0xE0434F4D是在mscorwks模块抛出,而0xE0434352是在clr模块抛出,结合《CLR调试时的sos.dll/clr.dll/mscorwks.dll/mscordacwks.dll等动态库的版本对应》一文,我们可以总结如下:
CLR Exception 0xE0434F4D和0xE0434352它们有一点区别是"CLR2.0版本是0xE0434F4D代码而在CLR4.0就已经改为0xE0434352"。
至于为什么会变,还待研究,也希望其他同好告知。同时也希望告知还有没有其他区别。
CLR Exception 0xE0434F4D和0xE0434352的区别的更多相关文章
- final,finally,finalize有什么区别?String, StringBuffer, StringBuilder有什么区别?Exception和Error有什么区别?
继上篇JVM学习之后,后面将分三期深入介绍剩余JAVA基础面试题,每期3题. 题目一.final,finally,finalize有什么区别? /*请尊重作者劳动成果,转载请标明原文链接:*/ /* ...
- Exception 和 Error 有什么区别么
声明 本篇所涉及的提问,正文的知识点,全都来自于杨晓峰的<Java核心技术36讲>,当然,我并不会全文照搬过来,毕竟这是付费的课程,应该会涉及到侵权之类的问题. 所以,本篇正文中的知识点, ...
- 《Java核心技术36讲》阅读笔记:Exception和Error有什么区别?
1.Exception 和 Error有什么区别?运行时异常与一般异常有什么区别? Exception和Error都继承自java.lang.Throwable.在Java中只有Throwable的实 ...
- java面试题(杨晓峰)---第二讲Exception和Error有什么区别?
本人总结: Exception和Error:正常问题和意外问题,以自行车举例:没气和爆胎. ①理解Throwable,Exception,Error的设计和分类. ②掌握哪些应用最广泛的子类, ③如何 ...
- Java学习|Exception和Error有什么区别?
典型回答: Exception和Error都继承了Throwable类,java中只有Throwable类型的实例才能被Throw(抛出)或者catch(捕获). Exceptio ...
- Java核心-02 Exception和Error有什么区别?
今天我要问你的问题是,请对比 Exception 和 Error,另外,运行时异常与一般异常有什么区别? 典型回答 Exception 和 Error 都是继承了 Throwable 类,在 Java ...
- Java Exception 和Error有什么区别?
① Exception 和Error 都是继承了Throwable类,在Java中只有Throwable类型的实例才可以被抛出或者捕获,它是异常处理机制的基本类型. ② Exception和Error ...
- java中exception和error有什么区别,运行时异常和一般异常有什么区别
1.exception和error都是继承了throwable类,在java中只有throwable类型的实例才可以被抛出(throw)或者捕获(catch),它是异常处理机制的基本组成类型 2.ex ...
- Java核心技术36讲----------Exception和Error有什么区别
1.异常知识点学习实例 代码如下: package fromnet; /** * 参考链接:https://blog.csdn.net/qq_18505715/article/details/7319 ...
随机推荐
- windows上MongoDB远程访问配置
今天用另一台机器上的MongoDB,但是使用本地连接时,没问题 换成IP地址时,出现 解决的方法,修改配置文件 systemLog: destination: file path: d:/Mongod ...
- Java连载17-赋值类运算符&字符串的连接运算符
一.赋值运算符 1.赋值类运算符包括两种: (1)基本赋值运算符:= (2)扩展的赋值运算符: += -= *= /= &= 赋值类的运算符优先级:先执行等号右边的表 ...
- Salesforce学习之路(二)Profile
如上篇文章所述,针对User来讲,最重要的概念便是Profile和Role,因为Profile于Security息息相关,这是一个合格的产品中十分重要的一环. 何为Profile? 前文所讲--就是一 ...
- 使用Ueditor上传图片到图片服务器(二)
上一篇主要写了前端部分如何配置ueditor的上传路径,已经jsp页面中如何使用ueditor的编辑器功能以及如何配置单独的图片上传功能. 这一篇,我分两部分:第一部分是搭建图片服务器以及配置ftp上 ...
- EF连接mysql,出现A call to SSPI failed错误,解决办法
我的使用场景是用EF连接AWS的mysql RDS,会偶发性的出现A call to SSPI failed错误, System.AggregateException: One or more err ...
- 我是如何一步步编码完成万仓网ERP系统的(八)产品库设计 4.品牌类别
https://www.cnblogs.com/smh188/p/11533668.html(我是如何一步步编码完成万仓网ERP系统的(一)系统架构) https://www.cnblogs.com/ ...
- 对Haskell这门语言的基本认识
Haskell语言的核心特征: 1. 函数式,而且是纯函数式(purely functional) 首先,引用一下维基百科上对“典型的函数式编程语言”的划分: 一: 纯函数式 1. 强静态类型: Mi ...
- 12个有趣的C语言问答
转自:http://www.admin10000.com/document/913.html 1,gets() 方法 Q:以下代码有个被隐藏住的问题,你能找到它吗? 1 2 3 4 5 6 7 8 9 ...
- vue中的---MVVM(面试必问)
M---Model (数据) V---View (视图) VM---VIewModel (转换器) VIewModel主要做两件事: 1.把 Model 中的数据绑定到View(视图层). 2.监 ...
- 简单mvc---模拟Springmvc
1.注解篇 Auwowrited package org.aaron.mvc.annaotation; import java.lang.annotation.Documented; import j ...