C# 静态构造函数使用
作者:网络转载 发布时间:[ 2015/6/30 13:51:41 ] 推荐标签:.NET 软件开发
当我们想初始化一些静态变量的时候,需要用到静态构造函数了。这个静态构造函数属于类,而不属于实例,是说这个构造函数只会被执行一次,即:在创建第一个实例或引用任何静态成员之前,由.NET自动调用。
现在碰到这样一个场景:提供一个静态方法,这个静态方法在不同的地方使用,涉及到一个参数值不同,而其他内容都完全一致。如果是将静态方法的内容复制出来做成另外一个方法,代码冗余太多,做法不可取。使用静态构造函数处理静态变量,则可以尽大程度简化代码。如下示例:
/// <summary>
/// 基类
/// </summary>
public class A
{
public static string Field = "original-test";
//静态构造函数
static A()
{
Field = "test-a";
}
public static void Test()
{
Console.WriteLine("the output is : " + Field);
}
}
/// <summary>
/// 子类
/// </summary>
public class B : A
{
//静态构造函数
static B()
{
Field = "test-b";
}
public static new void Test()
{
A.Test();//调用基类方法,这个对基类Test函数的覆盖很重要,没有这个,那么调用B.Test()的时候其实是调用基类的Test方法。
} }
如代码所示,类型B继承于基类型A。B中的静态构造函数对静态变量Field进行赋值,这个会在调用子类中的Test方法之前调用,而B中Test方法的实现则是完全调用基类A的Test方法,这样,在方法执行的时候,方法中使用的静态变量Field的值是在B的静态构造函数中赋值之后的test-b。
调用结果如下:
static void Main(string[] args)
{
A.Test();//输出the output is : test-a
B.Test();//输出the output is : test-b
Console.ReadLine();
}
A.Test()调用,Field值为test-a;而B.Test()调用,Field值为test-b。
这样,当静态方法的实现逻辑复杂的时候,可以针对需要将这个方法进行个性化实现的需求的时候简化代码:子类在静态构造函数中对静态变量重新赋值,然后重新实现基类中的静态方法。
(注意,后面的重新实现基类中的静态方法是必须的,否则输出B.Test()的时候,调用基类的Test()方法,使用的Field变量则是基类中的变量,那时输出则变成如下:)
static void Main(string[] args)
{
A.Test();//输出the output is : test-a
B.Test();//输出the output is : test-a。因为没有覆盖子类方法,等同于A.Test()
Console.ReadLine();
}
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11