次の例では、C は B から継承します。しかし C は仮想関数 F をオーバーライドできません。この仮想関数は A で宣言されており、B でシールされています。
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("X.F3"); }
}
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'.