(转)JITComplier、NGen.exe及.NET Native
一、JITComplier
如你所知,JIT(just-in-time或“即时”)编译器是CLR的重要组件,它的职责是将IL转换成本地cpu指令。
<<CLR via C#>>一书中在CLR的执行模型章节里有一副图形象介绍了一个方法(WriteLine)首次调用时发生的事情:

JITComplier函数被调用时,它知道要调用的是哪个方法,以及具体是什么类型定义了该方法。然后,JITComplier会在定义该类型的程序集的元数据中查找被调用的方法的IL,接着JITComplier验证IL代码,并最终将IL代码翻译成本地CPU指令。本地CPU指令被保存到一个动态分配的内存块中。
这里再插播一下MSIL。我们知道,.NET托管程序集同时包括元数据和IL。IL是与CPU无关的机器语言,可将它视为一种面向对象的机器指令,或者理解为一种高级汇编语言,但它比大多数CPU机器语言高级。IL能访问和操作对象类型,并提供了指令来创建和初始化对象、调用对象上的虚方法以及直接操作数组元素,甚至提供了抛出和捕获异常的指令来实现错误处理。
一个已经被JITComplier验证和编译过的方法,第二次调用时会直接执行内存块中的代码,完全跳过JITComplier函数,所以说一个方法只有在首次调用时才会造成一些性能损失。
JITComplier的主要特点:
1、运行时编译;
2、每次编译需要的方法;
3、编译后存在内存中;
4、编译器生成的代码会绑定到触发编译的进程上,不能多进程间共享。
二、NGen.exe
.NET Framework提供了NGen.exe工具,即本地代码生成器或本机映像生成器,可以在一个应用程序安装到用户的计算机上时,将IL代码编译成本地代码。
由于代码在安装时已经编译好,所以CLR的JITComplier不需要在运行时编译IL代码,这样看上去有助于提升应用程序的性能。
为什么说是“看上去”有助于提升应用程序的性能呢?NGen.exe不能提高.NET应用程序性能吗?你看,NGen.exe可以减少JITComplier的验证和编译,这部分开销难道不是省掉了吗?
实际上NGen.exe仅仅是加快应用程序的启动速度,执行时的性能并不比JITComplier编译的代码快。主要原因是,编译代码时, NGen无法像JIT编译器那样对最终的执行环境作出许多假设,这会造成NGen.exe产生较差的代码。例如, NGen不能优化一些CPU指令, 对静态字段的访问需要间接的操作而不能直接访问,因为静态字段实际的地址需要在运行时刻才能知道。NGen到处插入代码来调用类的构造函数,因为它不知道代码执行的次序,不知道类的构造函数是否已经被调用。
NGen.exe的主要特点:
1、在运行前编译;
2、一次编译整个程序集;
3、编译后持久地存储在本地的磁盘上;
4、可以多进程间共享已经编译好的代码。
当然,NGen.exe生成的文件也有一些典型的问题,比如没有知识产权保护、文件可能失去同步、难以管理、较差的执行时性能等,具体大家可以参考To-NGen-or-Not-to-NGen
可以通过命令行调用Framework下的NGen.exe工具,它的具体参数可以参考MSDN
三、.NET Native
最近这两天在博客和微博上都是热点。起因源自于微软在 MSDN 博客上宣布了 .NET Native 的开发者预览版。.NET Native 可以将 C# 代码编译成本地机器码。有了它,开发者将不仅能享受 C# 的高生产力,而且能拥有 C/C++般的性能。鱼与熊掌不可兼得,而有了 NET Native,我们可以兼得 C# 的生产力与 C++ 的战斗力。
看来MS这回是铁了心走高大上的道路了,功能和性能,效率和体验,平台和开源,一个都不能少。
参考:
<<CLR via C#>>
http://www.cnblogs.com/flier/archive/2004/07/08/22340.html
http://msdn.microsoft.com/en-US/vstudio/dn642499.aspx
http://blogs.msdn.com/b/dotnet/archive/2014/04/02/announcing-net-native-preview.aspx
(转)JITComplier、NGen.exe及.NET Native的更多相关文章
- JITCompiler、NGen.exe及.NET Native
一.JITCompiler 如你所知,JIT(just-in-time或“即时”)编译器是CLR的重要组件,它的职责是将IL转换成本地cpu指令. <<CLR via C#>> ...
- c#程序打包、机器代码生成(Ngen.exe)
深入本机影像生成器(Ngen.exe)工具使用方法详解 先介绍一点背景知识:.Net程序在运行时会实时(JIT)编译,将.Net程序文件编译成cpu认识的汇编机器码.实时编译需要消耗额外的cpu和内存 ...
- 谈谈JIT编译器和本机影像生成器(NGen.exe)
前言 在看<CLR>的时候,作者在开篇的时候提到了NGen.exe,前面一节执行程序集的代码中提到:程序或方法执行前会执行MSCorEE.dll中的JIT函数把要执行方法的IL转换成本地的 ...
- [CLR via C#]1.5 本地代码生成器:NGen.exe
原文:[CLR via C#]1.5 本地代码生成器:NGen.exe 1. NGen.exe工具,可以在一个程序安装到用户计算机时,将IL代码编译成为本地代码.由于代码在安装时已经编译好,所以CLR ...
- Ngen.exe和本机映像缓存
本机映像生成器创建托管程序集的本机映像,并且将该映像安装到本地计算机的本机映像缓存中.本机映像缓存是全局程序集缓存的保留区域.一旦您为某个程序集创建了本机映像,运行库在每次运行该程序集时就会自动使用该 ...
- .Net Framework 工具Mpgo.exe与Ngen.exe
首先放出官方MSDN的文档地址 Mpgo.exe 主要用于分析程序集启动时需要哪些东西,然后将信息反馈给NGen.exe 来更好的优化本机映像,使得应用程序启动更快,工作集缩小.准备发布时,用MPGO ...
- Ngen生成Native代码实战及优缺点分析
先科普一下,.Net是一个用于Windows的托管代码模型,用于高效构建具有视觉上引人注目的用户体验的应用程序.但这个模型生成的代码并非可执行代码,而是由.Net公共语言运行库环境执行的IL代码.所以 ...
- Native Application 开发详解(直接在程序中调用 ntdll.dll 中的 Native API,有内存小、速度快、安全、API丰富等8大优点)
文章目录: 1. 引子: 2. Native Application Demo 展示: 3. Native Application 简介: 4. Native Ap ...
- 【转】Gacutil.exe(全局程序集缓存工具)
全局程序集缓存工具使您可以查看和操作全局程序集缓存和下载缓存的内容. 安装 Visual Studio 和 Windows SDK 时会自动安装此工具. 要运行工具,我们建议您使用 Visual St ...
随机推荐
- iOS开发UI篇—UITableview控件基本使用
iOS开发UI篇—UITableview控件基本使用 一.一个简单的英雄展示程序 NJHero.h文件代码(字典转模型) #import <Foundation/Foundation.h> ...
- css关系选择器
1.包含选择符(E F) 选择所有被E元素包含的F元素,中间用空格隔开示例:<!DOCTYPE html><html> <head> <meta charse ...
- $('div','li'),$('div , li'),$('div li')的区别
要搞清楚$('div','li') 和 $('div , li') 和 $('div li') 区别: $('div','li'):是$(子,父),是从父节点里找子,而不是找li外面的div $('d ...
- XML 链接
公共Webservice 网络上可供测试的Web Service腾讯QQ在线状态 WEB 服务Endpoint: http://www.webxml.com.cn/webservices/qqOn ...
- Zabbix汉化方法
1.windows下选择一个汉化字体包 2.拷贝到linux字体目录下 [root@www Desktop]# cd /var/www/html/zabbix/fonts/[root@www font ...
- windows 7 32bit安装 python3.5.0 安装错误 0x80240017 -未指定错误
日志显示如下: [0F60:03D4][2015-10-20T10:47:52]i001: Burn v3.10.0.1823, Windows v6.1 (Build 7600: Service P ...
- [CQOI 2014] 数三角形 & 机械排序臂
数三角形 bzoj 3505 要知道一个公式就是(a,b)和(x,y)两点所成线段上面的整点数是gcd(a-x,b-y)-1,通过枚举原点到map上任意一点所能成的三角形,再平移,得到要去掉的三点共线 ...
- C++复习-练习-1
上周做多媒体技术的作业,JPEG编码问题:FDCT.量化.逆量化和IDCT,只是简单套公式,但还是感觉自己C++好渣...太久没做,手生了,可怕可怕. 所以复习了下文件操作和..基础操作.这里贴一些当 ...
- C语言修炼-第2天
从昨天被打击到下定决心以来,还是觉得学习代码是能让自己真正觉得充实的事情.其实潜意识里一直是这样的不是吗?从开始选择工科就没有后悔过,更不应该现在就放弃,其实自己的缺点本来就是不够扎实,给自己150天 ...
- C++ Daily 《1》----关于对象
1. 问题 请问如下的一个 class 的一个对象占了多少内存? 具体包含哪些东西? non-static 变量? static member 变量? member function?? virtua ...