在Java中有一個Super關鍵字,可以調用父類的構造方法和非私人成員。C#中使用的關鍵字是base,但用法不完全相同。
1. 調用父類的構造方法
// 父類
public class Father
{
public Father(String name)
{
this.name = name;
}
private String name;
}
// 子類
public class Son:Father
{
public Son(String name)
: base(name)
{
}
}
注意:
如果沒有第14行“:base(name)”,編譯器將報告錯誤:“Father”不包含採用“0”參數的建構函式。因為預設隱式調用
父類不帶參數的構造方法,而Father類沒有不帶參數的構造方法。所以此時需要像第14行那樣顯示調用父類構造方法。
2. 調用父類的成員
// 父類
public class Father
{
public String name = "小頭爸爸";
public void TellName()
{
Console.WriteLine("My name is {0}.",name);
}
}
// 子類
public class Son:Father
{
public new String name = "大頭兒子";
public new void TellName()
{
Console.Write("Father Told: ");
base.TellName();
Console.WriteLine("My Father's name is {0}",base.name);
Console.WriteLine("My name is {0}.", name);
}
}
如果不加第13行和第14行的關鍵字new,編譯器將產生2個警告,但不影響程式的運行。因為子類隱藏了父類的成員。
如果第4行和第13行的name成員是private,會少產生一個警告。
3. 子類的子類調用父類中的隱藏成員
一般情況,在調用父類成員時子2代和子1代沒什麼區別。但如果子1代隱藏父類成員,情況就會不同。
像上面的情況,Son隱藏了父類的成員變數name和成員方法TellName(),如果再有一個類Grandson繼承Son,那Grandson調用
Father類中被隱藏的成員時要像這樣:
// 子類的子類
public class Grandson : Son
{
public new String name = "大頭孫子";
public new void TellName()
{
Father f = this as Father;
Console.WriteLine("My Grandpa's name is {0}", f.name);
Console.WriteLine("My Father's name is {0}", base.name);
Console.WriteLine("My name is {0}.", name);
}
}
也可以使用強制轉換,第8行不要,第9行的“f.name”換成“((Father)this).name”。但是不能使用base進行強制轉換。
本文根據自己的學習心得,參考相關資源編寫而成。如果您發現錯誤或有疑問請發郵件到:lyjcn@126.com
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/lyjcn/archive/2008/12/09/3483912.aspx
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/huhai463127310/archive/2009/06/05/4244909.aspx