我知道有泛型擦除,但是我不知道该如何用泛型擦除来解释这个现象
在被一个序列化工具坑过后,经过测试,发现了一个我以前没注意到的 Java 特性盲点:
Java 允许这样操作:
List.class
但是他不允许这样的操作:
List.class
所以如果你有一个泛型方法需要传入 List的 Class类型的时候,用如下方式是错的
Jackson2JsonRedisSerializer> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer>(List.class);
只能用如下丑陋的方式
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(List.class);
于是,你想限定 List 容器里装什么,对不起,你限制不了,而且这玩意还会给你个警告,根据放狗的结果,不上压制警告注解的注解没法解决
然后我又够了好久,才发现还有一个迂回战术,能让你对 List 容器内部的类型进行限制,写法是下面这样的
Jackson2JsonRedisSerializer> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer>(
(Class>) new ArrayList().getClass());
新建一个容器的实现类泛型容器,然后调它的 getClass 方法。。。
虽然它也有一个必须用注解压制的警告,但是好歹能工作啊。
我自己查阅了不是关于 Java class 属性的资料,只能发现这玩意是编译后就被定义的属性,来自虚拟机本身,但是没有解释为什么 List.class 是不允许的。
所以,我的问题就是如何解释这个现象,其次就是如果我要拿到类似 List这样的类型的 Class;只能像上面那种迂回手段那样建哥对象让后 getClass 吗?