這篇文章主要講解了“什么情況下不能使用Java泛型”,文中的講解內(nèi)容簡單清晰,易于學(xué)習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習“什么情況下不能使用Java泛型”吧!
創(chuàng)新互聯(lián)長期為1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為西固企業(yè)提供專業(yè)的成都網(wǎng)站建設(shè)、做網(wǎng)站,西固網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
Java 1.5 引入了泛型來保證類型安全,防止在運行時發(fā)生類型轉(zhuǎn)換異常,讓類型參數(shù)化,提高了代碼的可讀性和重用率。但是有些情況下泛型也是不允許使用的,今天就總結(jié)一下編碼中不能使用泛型的一些場景。
以下寫法是錯誤的:
// error Map<int,char> wrong= new HashMap<>()
基本類型是不能夠作為泛型類型的,需要使用它們對應(yīng)的包裝類。
// OKMap<Integer,Character> wrong= new HashMap<>()
泛型類型可以理解為一個抽象類型,只是代表了類型的抽象,因此我們不能直接實例化它,下面的做法也是錯誤的:
public <E> E first(List<E> list){ // error E e = new E(); return list.get(0); }
Java 中的靜態(tài)類型隨著類加載而實例化,此時泛型的具體類型并沒有聲明。同時因為靜態(tài)變量作為所有對象的共享變量,只有類實例化或者方法調(diào)用時才能確定其類型。如果是泛型類型將無法確定其類型。同樣在類上聲明的泛型也無法作為返回值類型出現(xiàn)在類的靜態(tài)方法中,下面的寫法也是錯誤的:
public class Generic<T>{ // 不能將類聲明的泛型類型作為靜態(tài)變量 public static T t; // 也不能將類聲明的泛型類型作為 靜態(tài)方法的返回值 public static T rtval(List<T> list){ return list.get(0); } }
Java 中的泛型是偽泛型,在編譯期會被擦除,運行的字節(jié)碼中不存在泛型,所以下面的判斷條件無法進行:
public static <E> void wrong(List<E> list) { // error if (list instanceof ArrayList<Integer>) { } }
但是泛型的無界通配符
<?>
可以進行instanceof
判斷,你仔細想想為什么。
首先下面這種寫法是對的:
// OKList[] arrayOfLists = new List[2];
但是加上了泛型就編譯不通過了:
//errorList<Integer>[] arrayOfLists = new List<Integer>[2];
如果不這么規(guī)定將引發(fā)以下邏輯錯誤:
// 如果上面的成立,則下面的也應(yīng)該成立Object[] stringLists = new List<String>[]; // 那么我們可以放入 字符串 ListstringLists[0] = new ArrayList<String>(); // 放入 Integer liststringLists[1] = new ArrayList<Integer>();// 這顯然不合理
下面的兩種寫法將引發(fā)編譯錯誤:
// 不能間接地擴展 Throwable class IndirectException<T> extends Exception {} // 不能直接地擴展 Throwable class DirectException<T> extends Throwable {}
如果成立將出現(xiàn):
try { // ... } catch (T e) { // 類型不確定 無法處理具體的異常邏輯 }
你如何才能對異常進行具體的處理,這顯然不便于精確的異常處理邏輯。但是你可以拋出一個 不確定的異常,但是同樣不能在靜態(tài)方法中使用類聲明的泛型:
class Parser<T extends Exception> { // 這樣是對的 public void okThrow(File file) throws T { // ... } // 靜態(tài)方法不能出現(xiàn)類聲明的泛型類型作為返回值和異常 public static void wrongThrow(File file) throws T { } }
由于泛型擦除的原因,以下的不視為方法的重載且無法編譯 :
public class NoReload { public void sets(Set<String> strSet) { } public void sets(Set<Integer> intSet) { } }
感謝各位的閱讀,以上就是“什么情況下不能使用Java泛型”的內(nèi)容了,經(jīng)過本文的學(xué)習后,相信大家對什么情況下不能使用Java泛型這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!
網(wǎng)站欄目:什么情況下不能使用Java泛型
URL鏈接:http://m.rwnh.cn/article46/ipjehg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設(shè)計公司、云服務(wù)器、微信小程序、外貿(mào)建站、自適應(yīng)網(wǎng)站、品牌網(wǎng)站設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)