C# 构造函数中调用虚函数
生活随笔
收集整理的這篇文章主要介紹了
C# 构造函数中调用虚函数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
C# 構造函數中調用虛函數
using System; using System.Diagnostics; using System.Text; using System.Collections; using System.Collections.Generic;class Test {public class Base{public Base(){System.Console.WriteLine("Base.Base");ABitDangerousCall();}public virtual void ABitDangerousCall(){System.Console.WriteLine("Base.ABitDangerousCall");}private class Inner{public Inner(){System.Console.WriteLine("Base.Inner.Inner");}}private Inner inner = new Inner();}class Derived : Base{public Derived(){System.Console.WriteLine("Derived.Derived");ctorInitializedMember = 5;}// ctorInitializedMember is default initialized to zero before the constructor initializes it.private int ctorInitializedMember;private int derivedInt;public override void ABitDangerousCall(){System.Console.WriteLine(String.Format("Derived.ABitDangerousCallctorInitializedMember={0} derivedInt={1}", ctorInitializedMember, derivedInt));}private class Inner{public Inner(){System.Console.WriteLine("Derived.Inner.Inner");}}private Inner inner = new Inner();}class Program{static void Main(string[] args){Derived d = new Derived();Console.Read();}}}
輸出結果:
Derived.Inner.Inner
Base.Inner.Inner
Base.Base
Derived.ABitDangerousCallctorInitializedMember=0 derivedInt=0
Derived.Derived
由于實例構造函數的調用順序是先基類構造函數再子類構造函數,如上面例子,在基類中調用被子類重寫了的虛函數ABitDangerousCall時,實際會調用子類的ABitDangerousCall,
該函數中使用了變量ctorInitializedMember,但此時子類的構造函數還沒調用,故ctorInitializedMember未被賦值,這樣就出現了不想看到的結果。我們本來是想想看到ctorInitializedMember=5的結果,結果卻是0。
因此在基類的構造函數中調用虛函數是很危險的,項目大了代碼復雜了就很容易造成極隱蔽的BUG。同時在子類的構造函數中調用虛函數也是要小心的,盡量避免,原因同上。
如果非要調用,那就要細心察看虛函數中的變量是否已經全部在前面處理妥當了
posted on 2016-11-11 18:39 時空觀察者9號 閱讀(...) 評論(...) 編輯 收藏
總結
以上是生活随笔為你收集整理的C# 构造函数中调用虚函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LUA __call
- 下一篇: hashset hastable dic