java偽泛型知識點詳解
1、Java中的泛型是偽泛型。這種泛型實現(xiàn)方法稱為類型擦除 ,基于這種方法實現(xiàn)的泛型稱為偽泛型。
2、由于Java的泛型只在編譯階段發(fā)揮作用,因此在寫代碼時,起到了檢查的作用,當(dāng)代碼運行時,它的內(nèi)部并沒有泛型。
實例List<String> l1 = new ArrayList<String>();List<Integer> l2 = new ArrayList<Integer>();System.out.println(l1.getClass() == l2.getClass()); //true
結(jié)果為 true,List<String> 和 List<Integer> 在 jvm 中的Class都是List.class,即泛型信息被擦除了。
基礎(chǔ)知識點擴充:
泛型的基本概念
泛型的定義:泛型是JDK 1.5的一項新特性,它的本質(zhì)是參數(shù)化類型(Parameterized Type)的應(yīng)用,也就是說所操作的數(shù)據(jù)類型被指定為一個參數(shù),在用到的時候在指定具體的類型。這種參數(shù)類型可以用在類、接口和方法的創(chuàng)建中,分別稱為泛型類、泛型接口和泛型方法。
泛型思想早在C++語言的模板(Templates)中就開始生根發(fā)芽,在Java語言處于還沒有出現(xiàn)泛型的版本時,只能通過Object是所有類型的父類和類型強制轉(zhuǎn)換兩個特點的配合來實現(xiàn)類型泛化。例如在哈希表的存取中,JDK 1.5之前使用HashMap的get()方法,返回值就是一個Object對象,由于Java語言里面所有的類型都繼承于java.lang.Object,那Object轉(zhuǎn)型為任何對象成都是有可能的。但是也因為有無限的可能性,就只有程序員和運行期的虛擬機才知道這個Object到底是個什么類型的對象。在編譯期間,編譯器無法檢查這個Object的強制轉(zhuǎn)型是否成功,如果僅僅依賴程序員去保障這項操作的正確性,許多ClassCastException的風(fēng)險就會被轉(zhuǎn)嫁到程序運行期之中。
泛型技術(shù)在C#和Java之中的使用方式看似相同,但實現(xiàn)上卻有著根本性的分歧,C#里面泛型無論在程序源碼中、編譯后的IL中(Intermediate Language,中間語言,這時候泛型是一個占位符)或是運行期的CLR中都是切實存在的,List<int>與List<String>就是兩個不同的類型,它們在系統(tǒng)運行期生成,有自己的虛方法表和類型數(shù)據(jù),這種實現(xiàn)稱為類型膨脹,基于這種方法實現(xiàn)的泛型被稱為真實泛型。
Java語言中的泛型則不一樣,它只在程序源碼中存在,在編譯后的字節(jié)碼文件中,就已經(jīng)被替換為原來的原始類型(Raw Type,也稱為裸類型)了,并且在相應(yīng)的地方插入了強制轉(zhuǎn)型代碼,因此對于運行期的Java語言來說,ArrayList<int>與ArrayList<String>就是同一個類。所以說泛型技術(shù)實際上是Java語言的一顆語法糖,Java語言中的泛型實現(xiàn)方法稱為類型擦除,基于這種方法實現(xiàn)的泛型被稱為偽泛型。(類型擦除在后面在學(xué)習(xí))使用泛型機制編寫的程序代碼要比那些雜亂的使用Object變量,然后再進(jìn)行強制類型轉(zhuǎn)換的代碼具有更好的安全性和可讀性。泛型對于集合類來說尤其有用。
泛型程序設(shè)計(Generic Programming)意味著編寫的代碼可以被很多不同類型的對象所重用。
到此這篇關(guān)于java偽泛型知識點詳解的文章就介紹到這了,更多相關(guān)java偽泛型的介紹內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
