1. 前言
Java 1.5 引入了泛型来保证类型安全,防止在运行时发生类型转换异常,让类型参数化,提高了代码的可读性和重用率。但是有些情况下泛型也是不允许使用的,今天就总结一下编码中不能使用泛型的一些场景。
2. 基本类型无法直接使用泛型
以下写法是错误的:
// error
Map<int,char> wrong= new HashMap<>()
复制代码
基本类型是不能够作为泛型类型的,需要使用它们对应的包装类。
// OK
Map<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