我觉得最主要的原因是因为泛型擦除。
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 类型>