泛型---(静态方法中为什么不能引用类级别的参数)

我觉得最主要的原因是因为泛型擦除。
class Demo<T> {
public void add(T t) {

//...
}

}
编译后通过反编译:
D: est>javap -s -p Demo
Compiled from "Demo.java"
public class Demo extends java.lang.Object{
public Demo();
Signature: ()V
public void add(java.lang.Object);
Signature: (Ljava/lang/Object;)V
}
所以,非静态方法正是由于需要先有对象,进而在使用泛型的时候可以确定安全检查的限制条件。
Demo<String> d = new Demo<String>() ;
d.add("str") ; //这里你就只能添加String类型的。

而静态方法不需要构件对象,所以他在调用方法是,根本没有判断参数的约束条件,所以虚拟机压根就不希望这种事情发生,所以在编译时就报错了。

public class Test<T> {
    public static <T> void  test(T t){
        //......
    }
    
    public static void  test(T t){//Cannot make a static reference to the non-static type T
        //......
    }
}

<T>让static方法拥有泛型的能力。

泛型还可以用于内部类与匿名内部类

擦除的神秘之处:

  在泛型代码内部,无法发获得任何有关泛型参数类型的信息。(泛型的实现基于擦除机制)

泛型中的边界:example:<? extends 类型>

原文地址:https://www.cnblogs.com/jswang/p/7997763.html