现在的位置: 首页 > 综合 > 正文

Java 泛型 集合引用赋值问题(或方法传参)

2013年12月11日 ⁄ 综合 ⁄ 共 781字 ⁄ 字号 评论关闭

迷茫点A

List<String> a = null;
List<Object> b = null;
a = b;//compile error
b = a;//compile error

而下面有全可以

Object a = null;
String b = null;
a = b;
b = (String) a;

String[] a  = null;
Object[] b = null;
a = (String[]) b;
b = a;

为何会这样,全是因为java的泛型是伪泛型,假设说迷茫点A b = a是成功的(a = b成功是不可能的,即使在普通类型也需要强制转换),那么我们来分析一些过程。

a的引用使用了泛型,当a被编译了以后,生成的class中,a变成了List a,而把String去掉了。同理b 变成了List b;

那么这样a,b其实可以包含任何类型的对象。那么现在把a的引用复制给b,b这个时候如果add一个Integer对象,是完全可以的。b增加一个是没问题,但是其实a也增加了一个Integer对象,这个时候问题就出现了。因为a里面需要放的是String对象,但是编译过后,a并不一定要放String,那么在a中放入Integer也是可以的,这与客户期望的完全不同。所以为了避免这样的运行时错误在编译的时候java就组织了这个问题。

但是当时a,b都是数组的时候就不会有这个问题,在运行的时候就会出错,这个需要程序员自己去检查不要犯这样的错误。

当把a引用赋值给b后,在b数组中添加一个Integer,编译的时候是不会出错的,但是运行的时候就报错。

泛型还是可以指定边界的,上面的例子没有指定,默认就是Object,如果指定了边界在编译的时候,就指定最低也是这样的类型。

List<? extends String> a = null;
List<? extends Integer> b= null;

他们在编译的时候a就是不是List a了,而是List<String> a

抱歉!评论已关闭.