类型构造函数也称静态构造函数,用于初始化类型中的静态字段。
1,在类型中显式定义Static Constructor 来初始化静态成员:
internal
class
SomeType
{
static SomeType(){
m_i = 5;
}
private static Int32 m_i;
}
编译器会把静态构造函数标记为private ,静态构造函数通常由CLR 负责调用,所以应尽量避免编写要求类型构造函数按特定顺序调用的代码。
2,使用内联初始化静态字段:
internal
sealed
class
SomeType
{
private static Int32 m_i = 15; // 使用内联方式初始化静态字段
}
生成的IL 代码添加了一个.cctor 的私有静态构造函数 :
.method
private
hidebysig specialname rtspecialname
static
void
.cctor() cil managed
{
// Code size 8 (0x8)
.maxstack 8
IL_0000: ldc.i4.s 15
IL_0002: stsfld int32 HaiShui.Constructor.SomeType::m_i
IL_0007: ret
}
//
end of method SomeType::.cctor
类型构造函数的调用:
1,类显式定义了类型构造函数:创建实例对象、访问类的字段前调用Static Constructor,这种情况被称为 精确语义(precise semantic).
2,类中定义了静态字段,但类没有显式定义静态构造函数:访问静态字段前调用,这种情况被称为 字段初始化前语义(befor-field-init semantic).
Befor-Field-Init semantic 语义比较可取,性能更好,因为CLR 可以自由选择调用类型构造函数的时机,而且CLR 尽可能地充分利用这一优点来生成执行更快的代码。
1,在类型中显式定义Static Constructor 来初始化静态成员:
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/37c8bf68cdc3cc81759c34160776bc53.gif)
m_i = 5;
![](https://i-blog.csdnimg.cn/blog_migrate/717446ca04a6125dc5b6b54e0fa14ab4.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0196c3df5ea9e936f21e9932cca91014.gif)
2,使用内联初始化静态字段:
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0196c3df5ea9e936f21e9932cca91014.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6810355c2f78c12e91b7997a8e8c583a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/a41954a27d6ad96fa2c2cf816e677448.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a9c071a08f1dae2d3e1c512000eef41.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/0196c3df5ea9e936f21e9932cca91014.gif)
类型构造函数的调用:
1,类显式定义了类型构造函数:创建实例对象、访问类的字段前调用Static Constructor,这种情况被称为 精确语义(precise semantic).
2,类中定义了静态字段,但类没有显式定义静态构造函数:访问静态字段前调用,这种情况被称为 字段初始化前语义(befor-field-init semantic).
Befor-Field-Init semantic 语义比较可取,性能更好,因为CLR 可以自由选择调用类型构造函数的时机,而且CLR 尽可能地充分利用这一优点来生成执行更快的代码。