托管程序和非托管程序的区别

今天看了几个前辈的博文,有个概念自己一直没有注意,今天把它们整理下发出来:

引用博文:http://www.cnblogs.com/wuchang/archive/2006/12/07/584997.html

              http://www.cnblogs.com/springcsc/archive/2008/12/25/1362515.html

一般一个可执行文件的内部都包含一个PE头,系统根据PE的信息找到入口函数,在通过执行入口函数中的代码来执行可执行程序。托管程序的文件中相对于非托管程序还包含了一个CLR表头文件以及其他CLR需要的信息。

(1)非托管程序的执行过程
在非托管程序中,可执行里面保存的是机器代码,CPU可以直接加载并执行,当系统加载了可执行程序后,系统就将可执行文件的段基址加上偏移地址形成实际的物理地址,并直接加载到内存中运行。

(2)托管程序的执行过程

托管程序的可执行文件中,包含的是中间语言以及元数据,当然不能直接运行,必须启动CLR,由CLR对中间语言进行即时编译成机器代码,并加载到内存里面执行(具体过程:程序在进入入口函数前会提前跳转到MSCoree.dll中,调用它的代码来启动CLR并完成一些初始化工作)。当然,IL中的方法并不是每次被调用都会被编译一次,而是它只有在第一次调用时才进行编译,即时编译器会将方法名称以及对应的入口地址存放在映射表中,当下次调用该方法时,会直接从映射表里去而不是再编译一次。

因为托管程序在运行前首先要编译器对其进行编译成可执行代码,所以在效率上会有所下降,但到底下降多少,通过下面的实验看看吧。

原文地址:https://www.cnblogs.com/zcftech/p/2842750.html