For the latest documentation on C#, visit the C# Guide on docs.microsoft.com .
当对一个类应用 sealed 修饰符时,此修饰符会阻止其他类从该类继承. 在下面的示例中,类 B 从类 A 继承,但是任何类都不能从类 B 继承.
class A {}
sealed class B: A {}
还可以在重写基类中的虚方法或虚属性的方法或属性上使用 sealed 修饰符. 这将使您能够允许类从您的类继承,并防止它们重写特定的虚方法或虚属性.
示例
在下面的示例中,Z 从 Y 继承,但 Z 无法重写在 X 中声明并在 Y 中密封的虚函数 F.
C#
class X
{
protected virtual void F() { Console.WriteLine("X.F"); }
protected virtual void F2() { Console.WriteLine("X.F2"); }
}
class Y : X
{
sealed protected override void F() { Console.WriteLine("Y.F"); }
protected override void F2() { Console.WriteLine("Y.F2"); }
}
class Z : Y
{
// Attempting to override F causes compiler error CS0239.
// protected override void F() { Console.WriteLine("C.F"); }
// Overriding F2 is allowed.
protected override void F2() { Console.WriteLine("Z.F2"); }
}
当在类中定义新的方法或属性时,通过不将这些方法或属性声明为 virtual ,可防止派生类重写这些方法或属性.
将 abstract 修饰符用于密封类是错误的做法,因为抽象类必须由提供抽象方法或属性的实现的类继承.
当应用于方法或属性时,sealed 修饰符必须始终与 override 一起使用.
由于结构是隐式密封的,因此它们不能被继承.
有关更多信息,请参见 继承 .
有关更多示例,请参见 抽象类,密封类及类成员 .
示例
C#sealed class SealedClass {
public int x;
public int y;
}
class SealedTest2 {
static void Main() {
SealedClass sc = new SealedClass();
sc.x = 110;
sc.y = 150;
Console.WriteLine("x = {0}, y = {1}", sc.x, sc.y);
}
}
// Output: x = 110, y = 150
在上一个示例中,您可能尝试使用下面的语句从密封类继承:
class MyDerivedC: SealedClass {} // Error
将产生一条错误消息:
'MyDerivedC' cannot inherit from sealed class 'SealedClass'.
来源: http://www.bubuko.com/infodetail-2468784.html