国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

解析Java 泛型什么情況下不能使用

瀏覽:86日期:2022-09-01 17:41:36

一、前言

Java泛型來保證類型安全,防止在運行時發(fā)生類型轉(zhuǎn)換異常,讓類型參數(shù)化,提高了代碼的可讀性和重用率。但是有些情況下泛型也是不允許使用的,以下是不能使用泛型的一些場景。

二、 什么情況下不能使用Java泛型

1 不能使用泛型的形參創(chuàng)建對象。

T o=new T(); // 不允許

2 在泛型類中,不能給靜態(tài)成員變量定義泛型

Java 中的靜態(tài)類型隨著類加載而實例化,此時泛型的具體類型并沒有聲明。同時因為靜態(tài)變量作為所有對象的共享變量,只有類實例化或者方法調(diào)用時才能確定其類型。如果是泛型類型將無法確定其類型。同樣在類上聲明的泛型也無法作為返回值類型出現(xiàn)在類的靜態(tài)方法中,下面的寫法也是錯誤的:

以下是不允許的

public class A<T>{ public static T t; //錯誤 public T getA(){ //正確 ...... }}

下面也一樣

public class Generic<T>{ // 不能將類聲明的泛型類型作為靜態(tài)變量 public static T t; // 也不能將類聲明的泛型類型作為 靜態(tài)方法的返回值 public static T rtval(List<T> list){ return list.get(0); }}

3 泛型類不能繼承、不能直接或間接擴展java.lang.Throwable類

如下是不允許的

public class D<T> extends java.lang.Throwable //錯誤

下面的兩種寫法將引發(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 { }}

4 泛型類不能初始化一個數(shù)組、無法創(chuàng)建參數(shù)化類型的數(shù)組

如下所示不允許

T[] b = new T[10]; //錯誤

再看下面的情況

首先下面這種寫法是對的:

// 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>();// 這顯然不合理

5. 基本類型無法直接使用泛型

以下寫法是錯誤的:

// error Map<int,char> wrong= new HashMap<>()

基本類型是不能夠作為泛型類型的,需要使用它們對應(yīng)的包裝類。

// OKMap<Integer,Character> wrong= new HashMap<>()

6. 泛型類型無法被直接實例化

泛型類型可以理解為一個抽象類型,只是代表了類型的抽象,因此我們不能直接實例化它,下面的做法也是錯誤的:

public <E> E first(List<E> list){ // error E e = new E(); return list.get(0); }

7. 無法進行 instanceof 判斷

Java 中的泛型是偽泛型,在編譯期會被擦除,運行的字節(jié)碼中不存在泛型,所以下面的判斷條件無法進行:

public static <E> void wrong(List<E> list) { // error if (list instanceof ArrayList<Integer>) { }}

但是泛型的無界通配符 <?> 可以進行 instanceof 判斷,你仔細想想為什么。

8. 泛型擦除后相同參數(shù)簽名的方法不能重載

由于泛型擦除的原因,以下的不視為方法的重載且無法編譯 :

public class NoReload { public void sets(Set<String> strSet) { } public void sets(Set<Integer> intSet) { }}

到此這篇關(guān)于解析Java 泛型什么情況下不能使用的文章就介紹到這了,更多相關(guān)Java 不能泛型 內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Java
相關(guān)文章:
主站蜘蛛池模板: 阳西县| 阿瓦提县| 汨罗市| 潮州市| 汝州市| 龙南县| 泸定县| 山阴县| 大方县| 宜春市| 高安市| 涞水县| 阜城县| 巴彦县| 库车县| 邵武市| 凉山| 华安县| 镇坪县| 大冶市| 巴林右旗| 盐边县| 临沧市| 商丘市| 黔江区| 灵武市| 城市| 定襄县| 锡林郭勒盟| 榆社县| 盘锦市| 河北省| 彭山县| 灯塔市| 禹州市| 密云县| 海门市| 江门市| 馆陶县| 招远市| 华安县|