上篇文章轉載C++之父關於介面在實現中問題的回答後,自己動手寫了寫。但是由於之前用C#寫過一些程式,對abstract關鍵字理解不夠深,結果深受其害,查閱了很多關於虛函數、純虛函數、抽象類別以及介面的實現方面的資料,現將它們之間的聯絡區別整理一下。
一 抽象類別和介面
抽象類別: 抽象類別是特殊的類,只是不能被執行個體化(將定義了純虛函數的類稱為抽象類別);除此以外,具有類的其他特性;重要的是抽象類別可以包括抽象方法,這是普通類所不能的,但同時也能包括普通的方法。抽象方法只能聲明於抽象類別中,且不包含任何實現,衍生類別必須覆蓋它們。另外,抽象類別可以派生自一個抽象類別,可以覆蓋基類的抽象方法也可以不覆蓋,如果不覆蓋,則其衍生類別必須覆蓋它們。雖然不能定義抽象類別的執行個體,但是可以定義它的指標,這正是用抽象類別實現介面的重點所在。
介面: 介面是一個概念。它在C++中用抽象類別來實現,在C#和Java中用interface來實現。
介面是參考型別的,類似於類,和抽象類別的相似之處有三點:
1、不能執行個體化;
2、包含未實現的方法聲明;
3、衍生類別必須實現未實現的方法,抽象類別是抽象方法,介面則是所有成員(不僅是方法包括其他成員);
另外,介面有如下特性:
介面除了可以包含方法之外,還可以包含屬性、索引器、事件,而且這些成員都被定義為公有的。除此之外,不能包含任何其他的成員,例如:常量、域、建構函式、解構函式、靜態成員。一個類可以直接繼承多個介面,但只能直接繼承一個類(包括抽象類別)。
抽象類別和介面的區別:
1.類是對對象的抽象,可以把抽象類別理解為把類當作對象,抽象成的類叫做抽象類別.而介面只是一個行為的規範或規定,微軟的自訂介面總是後帶able欄位,證明其是表述一類類“我能做。。。”.抽象類別更多的是定義在一系列緊密相關的類間,而介面大多數是關係疏鬆但都實現某一功能的類中.
2.介面基本上不具備繼承的任何具體特點,它僅僅承諾了能夠調用的方法;
3.一個類一次可以實現若干個介面,但是只能擴充一個父類
4.介面可以用於支援回調,而繼承並不具備這個特點.
5.抽象類別不能被密封。
6.抽象類別實現的具體方法預設為虛的,但實現介面的類中的介面方法卻預設為非虛的,當然您也可以聲明為虛的.
7.(介面)與非抽象類別類似,抽象類別也必須為在該類的基類列表中列出的介面的所有成員提供它自己的實現。但是,允許抽象類別將介面方法映射到抽象方法上。
8.抽象類別實現了oop中的一個原則,把可變的與不可變的分離。抽象類別和介面就是定義為不可變的,而把可變的座位子類去實現。
9.好的介面定義應該是具有專一功能性的,而不是多功能的,否則造成介面汙染。如果一個類只是實現了這個介面的中一個功能,而不得不去實現介面中的其他方法,就叫介面汙染。
10.盡量避免使用繼承來實現組建功能,而是使用黑箱複用,即對象組合。因為繼承的層次增多,造成最直接的後果就是當你調用這個類群中某一類,就必須把他們全部載入到棧中!後果可想而知.(結合堆棧原理理解)。同時,有心的朋友可以留意到微軟在構建一個類時,很多時候用到了對象組合的方法。比如asp.net中,Page類,有Server Request等屬性,但其實他們都是某個類的對象。使用Page類的這個對象來調用另外的類的方法和屬性,這個是非常基本的一個設計原則。
11.如果抽象類別實現介面,則可以把介面中方法映射到抽象類別中作為抽象方法而不必實現,而在抽象類別的子類中實現介面中方法.
引自:http://blog.csdn.net/bmzyDream_007/archive/2009/05/07/4157560.aspx