查看override的IL

Override示例

下面我们看一个Override的Example

namespace MyCollection

{

    public class MyBase

    {

        public virtual string Meth1()

        {

            return "MyBase-Meth1";

        }

 

        public virtual string Meth2()

        {

            return "MyBase-Meth2";

        }

 

        public virtual string Meth3()

        {

            return "MyBase-Meth3";

        }

    }

 

    class MyDerived : MyBase

    {

        // 使用 override 关键字重写虚方法 Meth1:

        public override string Meth1()

        {

            return "MyDerived-Meth1";

        }

 

        // 使用 new 关键字显式隐藏

        // 虚方法 Meth2:

        public new string Meth2()

        {

            return "MyDerived-Meth2";

        }

 

        // 由于下面声明中没有指定任何关键字

        // 因此将发出一个警告来提醒程序员

        // 此方法隐藏了继承的成员 MyBase.Meth3():

        public string Meth3()

        {

            return "MyDerived-Meth3";

        }

    }

    public class VirtualExample

    {

        public static void Main()

        {

            MyDerived mD = new MyDerived();

            MyBase mB = (MyBase)mD;

 

            System.Console.WriteLine(mD.Meth1());

            System.Console.WriteLine(mD.Meth2());

            System.Console.WriteLine(mD.Meth3());

            System.Console.WriteLine("以上为类MyDerived的显示结果!\n");

 

            System.Console.WriteLine(mB.Meth1());

            System.Console.WriteLine(mB.Meth2());

            System.Console.WriteLine(mB.Meth3());

            System.Console.WriteLine("以上为MyBase的显示结果!\n");

            System.Console.WriteLine("按任意键退出...");

            System.Console.ReadLine();

        }

    }

}

运行结果

IL查看

双击查看Main方法

IL代码

.method public hidebysig static void  Main() cil managed

{

  .entrypoint

  // Code size       121 (0x79)

  .maxstack  1

  .locals init ([0] class MyCollection.MyDerived mD,

           [1] class MyCollection.MyBase mB)

  IL_0000:  nop

  IL_0001:  newobj     instance void MyCollection.MyDerived::.ctor()

  IL_0006:  stloc.0

  IL_0007:  ldloc.0

  IL_0008:  stloc.1

  IL_0009:  ldloc.0

  IL_000a:  callvirt   instance string MyCollection.MyBase::Meth1()//调用的是MyBase的Meth1()

  IL_000f:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0014:  nop

  IL_0015:  ldloc.0

  IL_0016:  callvirt   instance string MyCollection.MyDerived::Meth2()

  IL_001b:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0020:  nop

  IL_0021:  ldloc.0

  IL_0022:  callvirt   instance string MyCollection.MyDerived::Meth3()

  IL_0027:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_002c:  nop

  IL_002d:  ldstr      bytearray (E5 4E 0A 4E 3A 4E 7B 7C 4D 00 79 00 44 00 65 00   // .N.N:N{|M.y.D.e.

                                  72 00 69 00 76 00 65 00 64 00 84 76 3E 66 3A 79   // r.i.v.e.d..v>f:y

                                  D3 7E 9C 67 01 FF 0A 00 )                         // .~.g....

  IL_0032:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0037:  nop

  IL_0038:  ldloc.1

  IL_0039:  callvirt   instance string MyCollection.MyBase::Meth1()//这里一样调用的是MyBase的Meth1()

  IL_003e:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0043:  nop

  IL_0044:  ldloc.1

  IL_0045:  callvirt   instance string MyCollection.MyBase::Meth2()

  IL_004a:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_004f:  nop

  IL_0050:  ldloc.1

  IL_0051:  callvirt   instance string MyCollection.MyBase::Meth3()

  IL_0056:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_005b:  nop

  IL_005c:  ldstr      bytearray (E5 4E 0A 4E 3A 4E 4D 00 79 00 42 00 61 00 73 00   // .N.N:NM.y.B.a.s.

                                  65 00 84 76 3E 66 3A 79 D3 7E 9C 67 01 FF 0A 00 ) // e..v>f:y.~.g....

  IL_0061:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0066:  nop

  IL_0067:  ldstr      bytearray (09 63 FB 4E 0F 61 2E 95 00 90 FA 51 2E 00 2E 00   // .c.N.a.....Q....

                                  2E 00 )                                           // ..

  IL_006c:  call       void [mscorlib]System.Console::WriteLine(string)

  IL_0071:  nop

  IL_0072:  call       string [mscorlib]System.Console::ReadLine()

  IL_0077:  pop

  IL_0078:  ret

} // end of method VirtualExample::Main

 

IL解析

我们先回头看看源程序处的main内部的“System.Console.WriteLine(mD.Meth1());”语句对应上面的 IL_000a:  callvirt   instance string MyCollection.MyBase::Meth1() 和 IL_0039:  callvirt   instance string MyCollection.MyBase::Meth1()处的一模一样,原来它执行的是MyBase类的Meth1虚方法。而Meth1方法已经在 MyDerived类中重写了,所以这两个类的对应的方法1在本质说上都一样了。

通过看这个例子,我们能更加深入地理解override的功能了。看来ILdasm的确厉害,与其你想半天不如调IL代码看看,很多问题就会迎刃而解了,拨云见日啊!

文献资料

对于IL代码指令的具体含义请参考:http://www.cnblogs.com/zery/p/3366175.html

IL查看override的更多相关文章

  1. IL查看泛型

    查看泛型的IL 我们在开发中经常用到泛型,下面一起通过IL来查看泛型背后做了那些工作 示例代码 示例代码如下: using System;   namespace MyCollection { pub ...

  2. IL查看委托

    查看委托的IL 通过IL来查看委托的原理, 委托示例代码 写一个委托的类如下 using System;   namespace MyCollection { //定义一个类,该类包含两个静态方法 c ...

  3. IL接口和类的属性

    上一篇文章学习了IL的入门,接下来我们再通过两个例子来了解下类的属性.构造函数以及接口的使用 一.类的属性.构造函数 1.先看下我们要构建的类的C#代码,然后再进行IL的实现,示例代码如下: [Ser ...

  4. 30分钟?不需要,轻松读懂IL

    先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.net理解更深一点这些虚头巴脑的东西.最重要的理由就是一个 ...

  5. 读懂IL

    读懂IL 先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.net理解更深一点这些虚头巴脑的东西.最重要的理 ...

  6. 轻松读懂IL

    轻松读懂IL先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.net理解更深一点这些虚头巴脑的东西.最重要的 ...

  7. [No0000152]C#基础之IL,轻松读懂IL

    先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.net理解更深一点这些虚头巴脑的东西.其实IL本身逻辑很清 ...

  8. (转) 读懂IL

    引言 转自园子里的一片关于IL的好文,分享的同时,方便自己今后查阅. 原文链接:http://www.cnblogs.com/brookshi/p/5225801.html ------ 略过作者调侃 ...

  9. C#基础之IL ,轻松读懂中间代码IL 转载

    [No0000152]C#基础之IL,轻松读懂IL   先说说学IL有什么用,有人可能觉得这玩意平常写代码又用不上,学了有个卵用.到底有没有卵用呢,暂且也不说什么学了可以看看一些语法糖的实现,或对.n ...

随机推荐

  1. linux下log4j乱码解决

    使用log4j的时候,在WIN系统的时候正常显示中文,但是发布到linux系统的时候中文就显示成乱码了 由于log4j配置文件中没有设置编码格式(encoding),所以log4j就使用系统默认编码. ...

  2. Mybatis学习记录(五)----Mybatis的动态SQL

    1.  什么是动态sql mybatis核心 对sql语句进行灵活操作,通过表达式进行判断,对sql进行灵活拼接.组装. 1.1 需求 用户信息综合查询列表和用户信息查询列表总数这两个statemen ...

  3. 转:HTTP 1.1与HTTP 1.0的比较

    原文地址:http://blog.csdn.net/elifefly/article/details/3964766 HTTP 1.1与HTTP 1.0的比较 一个WEB站点每天可能要接收到上百万的用 ...

  4. 字符串匹配--Karp-Rabin算法

    主要特征 1.使用hash函数 2.预处理阶段时间复杂度O(m),常量空间 3.查找阶段时间复杂度O(mn) 4.期望运行时间:O(n+m) 本文地址:http://www.cnblogs.com/a ...

  5. iOS循环引用问题

    今天面试问道了循环引用,所以就看了看,原来只是知道使用了Block容易造成循环引用.今天就来简单的介绍一些循环引用. 先来简单介绍一下什么是循环引用? 循环引用可以简单的理解成:A对象引用了B对象,B ...

  6. iOS开发之网络编程--中文转码

    前言: 在GET请求或者是POST请求,请求上传的参数如果含有中文,可能会导致请求失败. 所以要对存储了URL地址的NSString对象进行中文转码,然后将这个NSString对象传递给URL.   ...

  7. android基础开发之RecycleView(1)---基本使用方式

    RecycleView是google为了优化listview,gridview 提供的一个新的控件. 1.android 导入recycleview 在app的gradle里面加入: dependen ...

  8. (转)Block的使用

    转:http://my.oschina.net/leejan97/blog/268536 本文翻译自苹果的文档,有删减,也有添加自己的理解部分. 如果有Block语法不懂的,可以参考fuckingbl ...

  9. hibernate一对一关系实现

    按照主键映射,按照外键映射 Address.hbm.xml: <?xml version="1.0"?><!DOCTYPE hibernate-mapping P ...

  10. jsp页面img利用tomcat配置访问服务器绝对路径显示图片

    1.打开tomcat下的server.xml文件,路径\apache-tomcat-7.0.62\conf文件夹下. 2.下<host></host>加入<Context ...