CS.CTOR.VIRTUAL

コンストラクタはそのクラスで定義された仮想メソッドを呼び出します

脆弱性とリスク

仮想メソッドが呼び出されると、メソッドを実行する実際の型は実行時まで選択されません。コンストラクタが仮想メソッドを呼び出したときに、メソッドを呼び出すインスタンスのコンストラクタがまだ実行可能ではない可能性があります。

例 1

コピー
  namespace NameSpace {
      class BadlyConstructedType {
          public BadlyConstructedType() {
              DoBusiness();         // defect - call to a virtual method
          }
          public virtual void DoBusiness() {
              // doing business...
          }
      }
 
     public class DerivedType : BadlyConstructedType {
         public DerivedType () {}
         public override void DoBusiness() {
             // this method is may be called when the corresponding object is not constructed...
         }
     }
 }