
import java.io.*; import java.util.*; public class ClassCasting { //@SuppressWarnings("unchecked") public void f(String[] args) throws Exception { ObjectInputStream in = new ObjectInputStream( new FileInputStream(args[0])); List<Integer> shapes = (List<Integer>)in.readObject(); // Won't Compile: //List<Integer> lw1 = List<Integer>.class.cast(in.readObject()); List lw2 = List.class.cast(in.readObject()); List<Integer> lw3 = List.class.cast(in.readObject()); } public static void main(String[] args) { } } ///:~ 这是 java 编程思想里面的一个小例子,里面有个小知识点。就是 List<Integer>.class 这样用不可以,但 List.class 这样用是可以的。
这里我用自己的话解释一波:因为泛型是假泛型,所以 Class 对象(public final class Class<T>)只能记住泛型类的原生类型 raw type。这么解释对吗?
1 chendy 2019 年 10 月 10 日 因为只有 List.class 没有 List<Integer>.class |
2 Raymon111111 2019 年 10 月 10 日 换个理解的方式 List<Integer> 这么写只是为了编译检查用的, 所以不存在对应的 class |
3 amiwrong123 OP |
4 ZredoC 2019 年 10 月 13 日 泛型只是编译阶段为了防止输入错误类型而存在的,可以通过反射的 invoke 操作绕过编译, |