Sealed密封类
当对一个类应用 sealed 修饰符时,此修饰符会阻止其他类从该类继承。 在下面的示例中,类 B 从类 A 继承,但是任何类都不能从类 B 继承。
class A {} sealed class B : A {}
还可以在重写基类中的虚方法或虚属性的方法或属性上使用 sealed 修饰符。 这将使您能够允许类从您的类继承,并防止它们重写特定的虚方法或虚属性。
在下面的示例中,Z 从 Y 继承,但 Z 无法重写在 X 中声明并在 Y 中密封的虚函数 F。
View Code
1 class X
2 {
3 protected virtual void F() { Console.WriteLine("X.F"); }
4 protected virtual void F2() { Console.WriteLine("X.F2"); }
5 }
6 class Y : X
7 {
8 sealed protected override void F() { Console.WriteLine("Y.F"); }
9 protected override void F2() { Console.WriteLine("X.F3"); }
10 }
11 class Z : Y
12 {
13 // Attempting to override F causes compiler error CS0239.
14 // protected override void F() { Console.WriteLine("C.F"); }
15
16 // Overriding F2 is allowed.
17 protected override void F2() { Console.WriteLine("Z.F2"); }
18 }
当在类中定义新的方法或属性时,通过不将这些方法或属性声明为 virtual,可防止派生类重写这些方法或属性。
将 abstract 修饰符用于密封类是错误的做法,因为抽象类必须由提供抽象方法或属性的实现的类继承。
当应用于方法或属性时,sealed 修饰符必须始终与 override 一起使用。
由于结构是隐式密封的,因此它们不能被继承。
1 sealed class SealedClass
2 {
3 public int x;
4 public int y;
5 }
6
7 class SealedTest2
8 {
9 static void Main()
10 {
11 SealedClass sc = new SealedClass();
12 sc.x = 110;
13 sc.y = 150;
14 Console.WriteLine("x = {0}, y = {1}", sc.x, sc.y);
15 }
16 }
17 // Output: x = 110, y = 150
在上一个示例中,您可能尝试使用下面的语句从密封类继承:
class MyDerivedC: SealedClass {} // Error
将产生一条错误消息:
'MyDerivedC' cannot inherit from sealed class 'SealedClass'.
攻城师~~