.ctor 是大家都知道的

.cctor 却不被人所熟习,也很容易被误用

所谓的的 .cctor 放在C#的语法中,就是静态的构造函数

形如

class  A

{

  static  A() // 这就是一个.cctor构造函数

}

.cctor  与 .ctor之间的异同

   1,不能有访问权限标识符 public,private,等等,都不能使用,这与.ctor不同

   2,不能有返回值,这与.ctor相同

   3,不能有参数,.ctor可以拥有多个参数

   4,最多只能有一个,.ctor至少要有一个

   5,程序员不能控制调用.cctor的时机,.ctor 从某种意义上说,程序员可以控制它调用的时机

   6,程序员无法直接调用.cctor , .ctor 当程序员使用new操作符时,.ctor是一定会被调用的

.cctor 的调用时机 :

    在创建第一个实例或引用任何静态成员之前,将自动调用静态构造函数。(这是MSDN上的原话)

    很明显,同一个程序域中.cctor 只会调用一次,而不是像.ctor每次实例化对象都会被调用

.cctor用处

    静态构造函数用于初始化任何静态数据,或用于执行仅需执行一次的特定操作。

举例说明:

以下所有代码 在 windows 7, vs 2005 Release 模式下编译确认,若结果不同,请考虑换成release模式重试

using System;


namespace only_lonely
{
    class A
    {
        static void Main(String[] args)
        {

        }
    }
}

 将此段代码编译,然后使用ILDASM查看,方法表如下

 .ctor() : void //这是由编译器自动提供的类的实例构造函数

 Main():void(string[]) //程序入口点

很显然,程序集中并没有.cctor 的身影,在类没有静态的字段需要初始化时,编译器是不会自动提供.cctor函数的,这又与.ctor不同,无论怎样,.ctor一直存在

修改代码

using System;


namespace only_lonely
{
    class A
    {
   
        static void Main(String[] args)
        {

        }

        static Int32 i = 0;
    }
}

编译此段代码,会有一个警告,但那并不重要的,重要的是用ILDASM查看程序集时,预料中的.cctor,静态构造函数并没有出现!

what happened?

难道推论错误了吗?.cctor并不是用来初始化类的静态字段?

take it easy ,请看一下段代码

using System;


namespace only_lonely
{
    class A
    {
   
        static void Main(String[] args)
        {

        }

        static Int32 i = 1;
    }
}

此段代码与上一段代码的唯一不同就是变更了静态字段i的初始值,接下来,就是见证神奇的时刻

让我们DASM 它,令人吃惊的是,千户万唤的.cctor终于出现了!

查看.cctor的实现代码,会看到

.method private hidebysig specialname rtspecialname static
        void  .cctor() cil managed
{
  // Code size       7 (0x7)
  .maxstack  8
  IL_0000:  ldc.i4.1  //实例化静态的字段 :-)
  IL_0001:  stsfld     int32 only_lonely.A::i
  IL_0006:  ret
} // end of method A::.cctor

为什么会是这样呢?可能的原因是 Int32 类型的默认值 就是 0,而编译器检测到了这个,所以便优化,不产生.cctor的代码

  参考 :

http://msdn.microsoft.com/zh-cn/library/k9x6w0hc%28VS.80%29.aspx