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