sealed 的中文意思是密封,顾名思义,就是由它修饰的类或方法将不能被继承或是重写。
在此类声明中使用sealed 可防止其它类继承此类;在方法声明中使用sealed 修饰符可防止扩充类重写此方法。
sealed 修饰符主要用于防止非有意的派生,但是它还能促使某些运行时优化。具体说来,由于密封类永远不会有任何派生类,所以对密封类的实例的虚拟函数成员的调用可以转换为非虚拟调用来处理。
密封类:
密封类在声明中使用sealed 修饰符,这样就可以防止该类被其他类继承。如果试图将一个密封类作为其它类的基类,C# 将提示出错。理所当然,密封类不能同时又是抽象类,因为抽象总是希望被继承的,
在哪些场合下使用密封类呢?实际上,密封类中不可能有派生类。如果密封类实例中存在虚成员函数,该成员函数可以转化为非虚有的,函数修饰符virtual 不再生效。
让我们看下面的例子:
abstract class AbstractClass { public abstract void Method(); } sealed class SealedClass : AbstractClass { public override void Method() { //..... } }
如果我们尝试写下面的代码
class OtherClass : SealedClass
{
}
C# 会指出这个错误,告诉你SealedClass 是一个密封类,不能试图从SealedClass 中派生任何类。
密封方法:
C# 还提出了密封方法(sealedmethod )的概念,以防止在方法所在类的派生类中对该方法的重载。对方法可以使用sealed 修饰符,这时我们称该方法是一个密封方法。
不是类的每个成员方法都可以作为密封方法,要作为密封方法必须对基类的虚方法进行重载,提供具体的实现方法。所以,在方法的声明中,sealed 修饰符总是和override 修饰符同时使用。请看下面的例子代码:
using System; class A { public virtual void F() { Console .WriteLine("A.F" ); } public virtual void G() { Console .WriteLine("A.G" ); } } class B : A { sealed override public void F() { Console .WriteLine("B.F" ); } override public void G() { Console .WriteLine("B.G" ); } } class C : B { override public void G() { Console .WriteLine("C.G" ); } }
类B 对基类A 中的两个虚拟方法均进行了重载,其中F 方法使用了sealed 修饰符,成为一个密封的方法。G 方法不是密封方法,所以在B 的派生类C 中,可以重载方法G ,但不能重载方法F