現在我要說的是C#中的版本處理.其實這是任何一個軟件必須要考慮的問題.每個軟件都不只一個版本(除了我寫的以外),因此版本處理顯得非常地重要.JAVA很好地處理了這個問題,而我個人認為C#借鑒了JAVA的處理方法,所以,也做得很好.
在C#中,如果你在聲明一個方法的時候用了virtual這個關鍵字,那麼,在派生類中,你就可以使用override或者new關鍵字來棄用它或是忽略它.如果你在父類中用了virtual這個關鍵字,而在其派生類中又沒有用override或new關鍵字,而直接引用一個同名方法的話,編譯器將會報錯,並將以new方式,即忽略派生類中的方法的方式來運行.下面的例子可以幫助你來理解:
000: // Versioning\versioning.cs 001: public class MyBase 002: { 003: public virtual string Meth1() 004: { 005: return "MyBase-Meth1"; 006: } 007: public virtual string Meth2() 008: { 009: return "MyBase-Meth2"; 010: } 011: public virtual string Meth3() 012: { 013: return "MyBase-Meth3"; 014: } 015: } 016: 017: class MyDerived : MyBase 018: { 019: public override string Meth1() 020: { 021: return "MyDerived-Meth1"; 022: } 023: public new string Meth2() 024: { 025: return "MyDerived-Meth2"; 026: } 027: public string Meth3() // 系統在這裡將會有一個警告,並且將會隱藏方法Meth3() 028: 029: 030: { 031: return "MyDerived-Meth3"; 032: } 033: 034: public static void Main() 035: { 036: MyDerived mD = new MyDerived(); 037: MyBase mB = (MyBase) mD; 038: 039: System.Console.WriteLine(mB.Meth1()); 040: System.Console.WriteLine(mB.Meth2()); 041: System.Console.WriteLine(mB.Meth3()); 042: } 043: }
輸出:
MyDerived-Meth1 MyBase-Meth2 MyBase-Meth3
可以很明顯地看出來,後兩個new關鍵字的輸出是父類中的方法的輸出,所以可以看出,new這個關鍵字的作用是如果在以前的版本中有這個方法,就沿用以前的方法,而不用我現在方法內容.而virtual的方法的作用正好相反,它的作用是如果在父類中有這樣一個方法,則用我現在寫的方法內容,讓以前的滾蛋!不過,這裡用new好象不太好,讓人誤解(糟了,蓋癡又要打我了!&*%$#@).
如果你把第037行去掉,把039-041中的mB全部改為mD,輸出又變為:
MyDerived-Meth1 MyDerived-Meth2 MyDerived-Meth3
這又說明了什麼呢,說明了派生類的對象只有在被父類重塑的時候,override和new關鍵字才會生效.呵呵,這樣說的確有點難以理解,大家只有自己動手,才能搞清楚這其中的機關,所謂"實踐是檢驗C#的唯一標准",哈哈!
在C#中,你可以自由地為在派生類中為加入一個方法,或者覆蓋父類的方法,如下所示,非常地簡單:
class Base {} class Derived: Base { public void F() {} } 和: class Base { public void F() {} } class Derived: Base { public void F() {} }
好了,這一節又完了,音樂還沒完,但是我真的要休息了,明天見!