01

中间语言(IL)

.Net中间语言(IL)的特性,很大程度上来自于要支持多语言互操作性。要支持多语言互操作性,是因为微软想搞一个大事情,将它的老产品线VB和VC++,VJ++都装入.Net架构中。要支持多语言互操作,就需要实现这些基本功能:

1) 继承:一种语言的类能继承另一种语言编写的类。

2) 组合:一种语言的类可以包含另外一种语言的类的实例。

3) 调用:一个对象能够调用其他语言编写的对象的方法。

4) 传递:值和对象应该能在不同类的方法之间传递(传递数据)。

5) 调试:调试器应能支持跨语言调试。

这里特别说明下:继承和组合。我们在学习所谓的“面向对象”的编程的时候,往往会用力过度,觉得对象化编程关键是“继承”,然后就设计出一堆继承关系。然而你要提醒自己,“组合”才是你应该多用的,因为继承观念虽好,但它有限制且复杂,因为.Net,Java是单一继承,而C++的多继承又特别复杂,概念虽美,但我们的目标是:更高效的写代码。举个例子,当你考虑B类继承A类时,考虑一下:B类包含A类,如何?这例子可以类比为:当你要继承你爸爸时,你考虑下,你包含你爸爸和你妈妈?我觉得后者更合适。因为你还要继承你妈妈,所以单一继承你爸爸不合适,而且你还会有你爸爸没有的技能,所以用包含挺好。

回到话题,上述如此宏伟的规划,.Net实现了。这就需要中间语言要提供强力支持。很显然我们可以想到,中间语言必须有相当程度的“对象化”特性,才能很好的支持这一点。我们来看看它的特征:

1) 面对对象和使用接口

面对对象相当于为不同语言建立了底层的“基本对象”,使不同语言有了相同的底层基础。使用接口使得不同语言可以遵循统一的“契约”(接口即契约)。

2) 区分值类型和引用类型

与其他编程语言一样,中间语言提供了预定义的基本数据类型。它分为值类型和引用类型,值类型存储在堆上,引用类型的实例则存储在堆栈上,堆和堆栈是两种不同的内存区域。

3) 强数据类型化

强数据类型化非常重要,它使得在不同语言间的数据传递变得简单而高效。中间语言通过“通用类型系统(CTS)”来预定义通用类型,通过“公共语言规范(CLS)”来确保语言的互操作性。

强数据类型化也使得中间语言可以实现对象化管理,从而实现了.Net的垃圾回收机制。中间语言通过“托管堆”存储对象,当托管堆满时调用垃圾回收器清理对象。

“应用程序域”也是个.Net的一个重要特性,传统的应用程序通过COM进行组件调用,此时应用程序和组件使用的是同一块内存,这容易因为COM组件的Bug而导致整个应用程序崩溃。而传统的通过比如CGI进程的方式来隔离内存,又存在进程开销比较大,进程间数据交换效率低的问题。而应用程序域很好的解决了这个问题。这依赖于中间语言的“强数据类型化”,强数据类型化隔绝了对内存的跨域访问,以及通过强类型化,使得数据可以以“对象”的方式传输,极大的提高了数据交换性能。当然应用程序域很少被应用,我自己几乎没用到,一般只在做类似开发工具Eclipse之类的插件式应用时才需要考虑。

4) 使用异常来处理错误

因为运行在中间语言之上的高级语言都使用了异常处理机制,所以中间语言需要支持异常的基础结构,使得异常能够在不同语言间传递必要的调试数据信息。

同Java一样,异常在C#中非常重要。因为历史原因,程序员们看到太多的代码都是使用更老旧的语言编写的,比如C,C++等,在这些传统语言中,一般使用方法的返回值来表示错误,比如返回-1表示错误类型1,返回-2表示错误类型2。这在.Net时代已经过时,我看到太多的人在错误的使用异常机制,还在走老旧的错误处理方式。这真是埋没了.Net优秀的异常机制,也是给自己编程挖坑的典范。记住一句话:你压根儿不应该在.Net框架下,考虑用返回值来表示错误!如果你发现在这么想,那么应该立即反省和思考。.Net下的返回值,只需要用于真正要返回的值,如果你的方法没有想要返回的值,那么方法的返回值就应该是void。

5) 使用特性(attribute)

中间语言也支持特性。在传统的C++编写COM时会使用特性,它一般是用于给编译器提供一些额外的信息。中间语言对特性进行了功能的拓展。我们可以自定义特性,可以使用反射来应用特性。这在ASP.Net MVC中体现的非常多,它实现了“面向切面编程”,使得代码能得到更好的复用。

后面将继续讲述“程序集”,“名称空间”等中间语言特性。

我们下回分解。

欢迎关注本人微信公众号,更及时的关注最新文章(每周三篇原创文章,以及多篇专题文章):

附文:

IL中间语言

探讨DotNET中数据集的强类型化(C#)

上一篇:解读经典-《C#高级编程》第七版-Chapter1-.Net体系结构-Page1-6

解读经典-《C#高级编程》第七版-Chapter1-.Net体系结构-Page6-13的更多相关文章

  1. c#高级编程第七版 学习笔记 第一章 .NET体系结构

    第一章      .NET体系结构 本章内容: 编译和运行面向.NET的代码 Microsoft中间语言(Microsoft Intermediate Language,MSIL或简称IL)的优点 值 ...

  2. c#高级编程第七版 学习笔记 第二章 核心c#

    第二章 核心C# 本章内容: 声明变量 变量的初始化和作用域 C#的预定义数据类型 在c#程序中使用条件语句.循环和跳转语句执行流 枚举 名称空间 Main()方法 基本的命令行c#编译器选项 使用S ...

  3. c#高级编程第七版 学习笔记 第三章 对象和类型

    第三章 对象和类型 本章的内容: 类和结构的区别 类成员 按值和按引用传送参数 方法重载 构造函数和静态构造函数 只读字段 部分类 静态类 Object类,其他类型都从该类派生而来 3.1 类和结构 ...

  4. ASP.NET MVC 4高级编程(第4版)

    <ASP.NET MVC 4高级编程(第4版)> 基本信息 作者: (美)Jon Galloway    Phil Haack    Brad Wilson    K. Scott All ...

  5. 《UNIX环境高级编程(第3版)》

    <UNIX环境高级编程(第3版)> 基本信息 原书名:Advanced Programming in the UNIX Environment (3rd Edition) (Addison ...

  6. 【转】apue《UNIX环境高级编程第三版》第一章答案详解

    原文网址:http://blog.csdn.net/hubbybob1/article/details/40859835 大家好,从这周开始学习apue<UNIX环境高级编程第三版>,在此 ...

  7. Linux - Unix环境高级编程(第三版) 代码编译

    Unix环境高级编程(第三版) 代码编译 本文地址:http://blog.csdn.net/caroline_wendy 时间:2014.10.2 1. 下载代码:http://www.apuebo ...

  8. Unix环境高级编程第三版中实例代码如何在自己的linux上运行的问题

    学习Linux已经有2个月了,最近被期末考试把进度耽误了,前几天把Unix环境高级编程看了两章,感觉对Linux的整体有了一些思路,今天尝试着对第一章涉及到的一个简单的交互式shell编译运行一下,结 ...

  9. C#高级编程 (第六版) 学习 第七章:委托和事件

    第七章 委托和事件 回调(callback)函数是Windows编程的一个重要方面,实际上是方法调用的指针,也称为函数指针. .Net以委托的形式实现了函数指针的概念,.Net的委托是类型安全的. 委 ...

  10. C#高级编程第11版 - 第七章 索引

    [1]7.1 相同类型的多个对象 1.假如你需要处理同一类型的多个对象,你可以使用集合或者数组. 2.如果你想使用不同类型的不同对象,你最好将它们组合成class.struct或者元组. [2]7.2 ...

随机推荐

  1. android判断密码首字母大写正则表达式

    判断首字母大写"[A-Z]\\w+" \\w所有字符 \\d所有数字

  2. Runnable与Callable区别

    相同点: 两者都是接口:(废话) 两者都可用来编写多线程程序: 两者都需要调用Thread.start()启动线程: 不同点: 两者最大的不同点是:实现Callable接口的任务线程能返回执行结果:而 ...

  3. Z-Stack - Modification of Zigbee Device Object for better network access management

    写一份赏心悦目的工程文档,是很困难的事情.若想写得完善,不仅得用对工具(use the right tools),注重文笔,还得投入大把时间,真心是一件难度颇高的事情.但,若是真写好了,也是善莫大焉: ...

  4. ANDROID说说对MENU的理解

    ANDROID%E5%88%9D%E5%AD%A6%E4%B9%8B%E7%AE%80%E6%98%93%E8%AE%A1%E7%AE%97%E5%99%A8 Ѿ�����ڴ����㺰ô�

  5. win10 win7 环境下 oracle 11g和Plsql的安装、卸载遇到的问题。

    * win7一体机在安装好oracle和PlSQL后,无法连接到orcl数据库,同时也忘记了sys设置的密码.(在这里应注意在安装过程中,应选择统一口令,这里我均设置成了orcl,同时也应该注意在最后 ...

  6. day_10初级函数

    今天讲了函数初级 函数:完成特定功能的代码块,作为一个整体对其进行特定的命名,该名字就是代表函数 --现实中很多问题要通过一些工具进行处理 ,,可以将工具提前准备好并命名 通过名字就可以找到这个工具 ...

  7. 背水一战 Windows 10 (96) - 选取器: ContactPicker

    [源码下载] 背水一战 Windows 10 (96) - 选取器: ContactPicker 作者:webabcd 介绍背水一战 Windows 10 之 选取器 ContactPicker(联系 ...

  8. .net的服务转移

    问题: 服务器换新,但是本来服务器部署了一些window服务,需要迁移过来 解决过程: 百度了估计几百页了,之前因为老机器挂了,写这个代码布服务的人也早就不在了,所以自己闷头苦找,一个java初级程序 ...

  9. 第79节:Java中一些要点

    第79节:Java中一些要点 前言 一些知识点忘了没,可以通过一个点引出什么内容呢?做出自己的思维导图,看看自己到了哪一步了呢 内容 如果有人问jre,jdk,jvm是什么,你怎么回答呢? jre的英 ...

  10. SpringMVC框架四:异常处理器

    .异常分为:预期异常.运行时异常 dao.service.controller三层中有异常,依次向上抛出直到SpringMVC处理. 而SpringMVC交给HandlerExceptionResol ...