一、Java中的泛型與C中的泛型的區別
它們之間有很大的區別。在C ++中,您不必為泛型類型指定類或接口。這就是為什么您可以創建真正的泛型函數和類,而不必擔心松散的鍵入。
1 | template? |
上面的方法添加了兩個相同類型的對象,并且可以用于任何具有” +”運算符的類型T。
在Java中,如果要在傳遞的對象上調用方法,則必須指定一種類型,例如:
1 |
在C ++中,泛型函數/類只能在標頭中定義,因為編譯器會針對不同的類型(使用其調用)生成不同的函數。因此編譯速度較慢。在Java中,編譯不會帶來很大的損失,但是Java使用一種稱為”擦除”的技術,其中泛型在運行時被擦除,因此在運行時Java實際上正在調用…
1 | Something sum(Something a, Something b)?{?return?a.add?(?b?);?} |
因此,Java中的通用編程并不是真正有用,它只是語法上的一點幫助新的foreach構造。
基本上,在C ++中,模板基本上是經過修飾的預處理器/宏集(注意:由于某些人似乎無法理解類推,因此我并不是說模板處理是宏)。在Java中,它們基本上是語法糖,可以最大程度地減少對象的樣板轉換。這是對C ++模板與Java泛型的相當不錯的介紹。
要詳細說明這一點:使用C ++模板時,基本上是在創建代碼的另一個副本,就像使用#define宏一樣。這使您可以執行諸如在模板定義中使用int參數來確定數組大小等操作。
延伸閱讀:
二、C++泛型
C++泛型跟虛函數的運行時多態機制不同,泛型支持的靜態多態,當類型信息可得的時候,利用編譯期多態能夠獲得最大的效率和靈活性。當具體的類型信息不可得,就必須訴諸運行期多態了,即虛函數支持的動態多態。
對于C++泛型,每個實際類型都已被指明的泛型都會有獨立的編碼產生,也就是說list和list生成的是不同的代碼,編譯程序會在此時確保類型安全性。由于知道對象確切的類型,所以編譯器進行代碼生成的時候就不用運用RTTI,這使得泛型效率跟手動編碼一樣高。
顯然這樣的做法增加了代碼空間,相比運行時多態,是以空間換時間。