什么情况下不能使用Java泛型

发布时间:2021-11-02 14:19:04 作者:iii
来源:亿速云 阅读:144

这篇文章主要讲解了“什么情况下不能使用Java泛型”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“什么情况下不能使用Java泛型”吧!

1. 前言

Java 1.5 引入了泛型来保证类型安全,防止在运行时发生类型转换异常,让类型参数化,提高了代码的可读性和重用率。但是有些情况下泛型也是不允许使用的,今天就总结一下编码中不能使用泛型的一些场景。

2. 基本类型无法直接使用泛型

以下写法是错误的:

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

基本类型是不能够作为泛型类型的,需要使用它们对应的包装类。

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

3. 泛型类型无法被直接实例化

泛型类型可以理解为一个抽象类型,只是代表了类型的抽象,因此我们不能直接实例化它,下面的做法也是错误的:

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

4. 泛型无法作为静态变量类型

Java 中的静态类型随着类加载而实例化,此时泛型的具体类型并没有声明。同时因为静态变量作为所有对象的共享变量,只有类实例化或者方法调用时才能确定其类型。如果是泛型类型将无法确定其类型。同样在类上声明的泛型也无法作为返回值类型出现在类的静态方法中,下面的写法也是错误的:

public class Generic<T>{    // 不能将类声明的泛型类型作为静态变量
    public static T t;    // 也不能将类声明的泛型类型作为 静态方法的返回值
    public  static  T  rtval(List<T> list){        return list.get(0);
    }
}

5. 无法进行 instanceof 判断

Java 中的泛型是伪泛型,在编译期会被擦除,运行的字节码中不存在泛型,所以下面的判断条件无法进行:

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

但是泛型的无界通配符 <?> 可以进行 instanceof 判断,你仔细想想为什么。

6. 无法创建参数化类型的数组

首先下面这种写法是对的:

// OKList[] arrayOfLists = new List[2];

但是加上了泛型就编译不通过了:

//errorList<Integer>[] arrayOfLists = new List<Integer>[2];

如果不这么规定将引发以下逻辑错误:

// 如果上面的成立,则下面的也应该成立Object[] stringLists = new List<String>[];  
// 那么我们可以放入 字符串 ListstringLists[0] = new ArrayList<String>();   
// 放入 Integer liststringLists[1] = new ArrayList<Integer>();// 这显然不合理

7. 不能直接或者间接扩展Throwable

下面的两种写法将引发编译错误:

//  不能间接地扩展 Throwable   class IndirectException<T> extends Exception {}     
//  不能直接地扩展 Throwable  class DirectException<T> extends Throwable {}

如果成立将出现:

 try {        // ...
    } catch (T e) {   
        // 类型不确定  无法处理具体的异常逻辑
    }

你如何才能对异常进行具体的处理,这显然不便于精确的异常处理逻辑。但是你可以抛出一个 不确定的异常,但是同样不能在静态方法中使用类声明的泛型:

class Parser<T extends Exception> {   // 这样是对的
    public void okThrow(File file) throws T {      
        // ...
    }    // 静态方法不能出现类声明的泛型类型作为返回值和异常
    public static void wrongThrow(File file) throws T {      
    }
}

8. 泛型擦除后相同参数签名的方法不能重载

由于泛型擦除的原因,以下的不视为方法的重载且无法编译 :

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

感谢各位的阅读,以上就是“什么情况下不能使用Java泛型”的内容了,经过本文的学习后,相信大家对什么情况下不能使用Java泛型这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

推荐阅读:
  1. 如何理解java泛型
  2. 如何使用Java泛型

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Shellcode生成方法是什么

下一篇:好用的Linux网络监控工具有哪些

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》