標籤:style blog color 使用 io strong div 代碼 log
在物件導向的編程中,倆種截然不同的繼承類型:實現繼承和介面繼承。
實現繼承:表示一個類型派生於一個基底類型,它擁有該基底類型的所有成員欄位和函數。
介面繼承:表示一個類型只繼承了函數的簽名,沒有繼承任何實現代碼。
C#不支援多重實現繼承
C#類可以派生自另一個類和任意多個介面
虛方法
把一個基類函式宣告為virtual,就可以在任何衍生類別中重寫該函數
可以把屬性聲明為virtual
C#要求在派生的函數重寫另一個函數時,要使用override關鍵字顯式聲明
class MyBaseClass{ public virtual string VirtualMethod() { return "This Method is virtual and defined in MyBaseClass"; }}class MyDerivedClass:MyBaseClass{ public override string VirtualMethod() { return "This method is an override defined in MyDerivedClass"; }}
如果簽名相同的方法在基類和衍生類別中都進行了聲明,但該方法沒有分別聲明為virtual 和override,衍生類別方法就會隱藏基類方法。
C#有一種特殊的文法用於衍生類別中調用方法的基類版本:base.<MethodName>()。
class CustomerAccount{ public virtual decimal CalculatePrice() { //implementation return 0.0 ; }}class GoldAccount:CustomerAccount{ public override decimal CalculatePrice() { return base,CalculatePrice() * 0.9M; }}
抽象類別和抽象函數
C#允許把類和函式宣告為abstract。
抽象類別不能執行個體化,
而抽象函數不能直接實現,必須在非抽象的衍生類別中重寫。抽象函數本身也是虛擬(不需要提供virtual關鍵字)
如果類包含抽象函數,則該類也是抽象的,也必須聲明為抽象的。
密封類和密封方法
C#允許把類和方法聲明為sealed
對於類,表示不能繼承該類;對於方法,表示不能重寫該方法。
要在方法或屬性上使用sealed關鍵字,必須先從基類上把它聲明為要重寫的方法或屬性。
class MyClass:MyClassBase{ public sealed override void FinalMethod() { //etc. }}
衍生類別的建構函式
建構函式的調用順序是先調用System.Object,再按照階層由上向下進行,直到達到編譯器要執行個體化的類為止。
修飾符
public 任何代碼均可以訪問該項
protected 只有派生的類型能訪問該項
internal 只能在包含它的程式集中訪問該項
private 只能在它所屬的類型中訪問該項
protected internal 只能在包含它的程式集和衍生類別型的代碼中訪問該項
new 成員用相同的簽名隱藏繼承的成員
static 成員不作用與類的具體執行個體
virtual 成員可以由衍生類別重寫
abstract 虛擬成員定義了成員的簽名,但沒有提供實現代碼
override 成員重寫了繼承的虛擬或抽象成員
sealed 對於類,不能繼承自密封類。對於屬性和方法,成員重寫已繼承的虛擬成員,但是任何衍生類別中的任何成員都不能重寫該成員。該修飾符必須與override一起使用。
extern 成員在外部用另一種語言實現(僅靜態[DllImport]方法)
介面
一般情況下,介面只能包含方法、屬性、索引器和事件的聲明
介面不能有建構函式
不能有欄位
也不允許包含運算子多載
不允許聲明關於成員的修飾符
介面成員總是公有的,不能聲明為虛擬或靜態
介面可以彼此繼承,其方式或類的繼承方式相同。
C#學習筆記 ----繼承