2

我试着用一个例子来解释这个问题。我有一个名为 X 的接口和一个实现 X 的类 Y。Y 的几个实例收集在一个列表中。现在这是我不太明白的一点。当我尝试将此列表分配给集合时,我收到编译器错误。否则,当我将此列表分配给集合时,它会起作用。

List<Y> yList = new ArrayList<Y>();
// works
Collection<? extends X> coll1 = yList;
// error
Collection<X> coll2 = yList;

谁能解释这两个变体之间的区别以及为什么第二个变体不起作用。

4

1 回答 1

1

为此,您需要更多地了解泛型的概念。

我们来看下面的代码:

List<Integer> ints = new ArrayList<Integer>();
ints.add(Integer.valueOf(1));
List<Number> numbers = ints;// This does not compile! and you will now see why:

numbers.add(new Double(2.3d));// This is valid
Integer i = ints.get(1); // This would be broken then because I expect an Integer but get a Double

这就是为什么您需要将您List<X>Collection<? extends Y>意思转换为集合包含扩展 Y 但您不知道确切类型的对象的原因。您知道可以强制转换为 (Y),但您不知道集合中的实际类型是什么,因此不允许 add() 或 addAll() 之类的操作。

于 2012-04-16T13:38:27.350 回答