• Inside C#(一些内部实现的东西)


    ILDASM是个好的工具,平时也很喜欢用,它能帮助我更好的了解NET。以下我的总结,请执教。

    You write:

    public enum Compression {

       Zip, SuperZip, None

     }

    The C# compiler generates:

    public struct Compression : Enum {

       public int value__;

       public const Compression Zip = 0;

       public const Compression SuperZip = 1;

       public const Compression None = 2;

    }
    What can we learn:
    1)Enums 是struct ,内部成员即是struct 也是Enum 。
    2)Enum 继承System.Enum 的,structs可以继承ValueType,也可以是Enum 。
    3)Enum 内部成员默认是Int的。
    4)变量含有”__“的不能使用。
    5)所有的值都是const 的,因此在没有重新编译的时候是不能改变的,而且也是类型安全的。
     

    You write:

    public class Resource

    {

       ~Resource() {

          ...

       }

    }

    The C# compiler generates:

    public class Resource

    {

       protected override void Finalize() {

          try {

             ...

          }

          finally {

             base.Finalize();

          }

       }

    }

    What can we learn:
    1)解析函数是重写基类的finalize 的。且是不确定的。
    2)method (represented by the “…”)是放在Try里,无论有没有异常都会调用基类的finalize 。

    You write:

    using (Resource res = new Resource()) {

       res.DoWork();

    }

    The C# compiler generates:

    Resource res = new Resource(...);

    try {

       res.DoWork();

    }

    finally {

       if (res != null)
          ((IDisposable)res).Dispose();

    }

    What can we learn:

    使用using 会被编译成try,且会始终执行Dispose方法(基于CLR的异常)。

    You write:

    object x = ... ;

    lock (x) {

       // critical section

    }

    The C# compiler generates:

    System.Threading.Monitor.Enter(x);
    try {
       // critical section
    }
    finally {
       System.Threading.Monitor.Exit(x);
    }

    What can we learn:
    1)       Lock just uses Monitor.Enter and Exit… reading those docs give you a good idea of what is really happening here.
    2)       We see our friend try..finally again. This time ensuring that the monitor is exited even if an exception is thrown in the critical section

    You write:
    ArrayList list = new ArrayList();
    foreach(int x in list) { // do nothing }

    The C# compiler generates:
    ArrayList list1;
    int num1;
    IEnumerator enumerator1;
    IDisposable disposable1;
    list1 = new ArrayList();
    enumerator1 = list1.GetEnumerator();
    try { 
            while (enumerator1.MoveNext()) { 
                num1 = ((int) enumerator1.Current);
             } 
            return;
     }
    finally { 
                disposable1 = (enumerator1 as IDisposable); 
                if (disposable1 != null) { 
                        disposable1.Dispose(); 
                    }
    }

    版权所有归"布衣软件工作者".未经容许不得转载.
  • 相关阅读:
    多路径下使用ASMLIB创建ASM磁盘
    linux7.4开启hugepages
    Oracle 12CR2 RAC 升级
    深度思考比勤奋更重要(转)
    Oracle最大保护模式是有延迟的
    mysql主从安装简记
    Socket 监控服务器运行状态
    12C Sharding 学习安装
    惊喜与局限并存,12c Sharding内测报告抢先看!
    Oracle 12c 分片(Sharding)技术
  • 原文地址:https://www.cnblogs.com/gjcn/p/1089920.html
Copyright © 2020-2023  润新知