使用 abstract 关键字可以创建抽象类,抽象类不能被实例化,只能通过派生类中实现的类和类成员。 //字面意思 抽象的东西没有具体的方法体和内容,只有在子类里实现。
使用 sealed 关键字可以创建密封类,其作用防止继承被其它类继承。 //字面意思可以明白密封的意思就是将自己封闭起来,防止被其它使用。
public abstract class A { // Class members here. }
抽象类不能实例化。 抽象类的用途是提供一个可供多个派生类共享的通用基类定义。 例如,类库可以定义一个抽象类,将其用作多个类库函数的参数,并要求使用该库的程序员通过创建派生类来提供自己的类实现。//类似接口
抽象类也可以定义抽象方法。 方法是将关键字 abstract 添加到方法的返回类型的前面。 例如:
public abstract class A { public abstract void DoWork(int i); }
抽象方法没有实现,所以方法定义后面是分号,而不是常规的方法块。 抽象类的派生类必须实现所有抽象方法。 当抽象类从基类继承虚方法时,抽象类可以使用抽象方法重写该虚方法。 例如:
// compile with: /target:library public class D { public virtual void DoWork(int i) { // Original implementation. } } public abstract class E : D { public abstract override void DoWork(int i); } public class F : E { public override void DoWork(int i) { // New implementation. } }
如果将 virtual 方法声明为 abstract,则该方法对于从抽象类继承的所有类而言仍然是虚方法。 继承一个抽象方法的类不能访问该方法的原始实现。在上一个示例中,类 F 中的DoWork 不能调用类 D 中的 DoWork。 通过这种方式,抽象类可以强制派生类为虚方法提供新的方法实现。
public sealed class D { // Class members here. }
密封类不能用作基类。 因此,它也不能是抽象类。 密封类禁止派生。 由于密封类从不用作基类,所以有些运行时优化可以略微提高密封类成员的调用速度。
在对基类的虚成员进行重写的派生类上,方法、索引器、属性或事件可以将该成员声明为密封成员。 在用于以后的派生类时,这将取消成员的虚效果。 方法是在类成员声明中将sealed 关键字置于 override 关键字的前面。 例如:
public class D : C { public sealed override void DoWork() { } }
密封类的使用和普通的类相似,只是将自己密封起来,防止被继承。