这是不可能的。通用信息仅在编译时可用。但是,直到运行时才能知道列表列表的确切内容和结构。因此,编译器无法保证每个列表将包含什么。如果您事先知道列表的结构,那么最好考虑一个控股类,例如。
class Holder<T,S> {
List<T> listOfTs;
List<S> listOfSs;
}
如果您知道这些列表都将共享一个共同的超类型,那么您可能希望使用通配符边界。
List<List<? extends Shape>> list = new ArrayList<List<? extends Shape>>();
list.add(new ArrayList<Circle>());
list.add(new ArrayList<Square>());
这将允许您根据列表的超类型来操作列表。通配符限制的问题是您不能将任何元素添加到通配符限制的集合中。
考虑以下:
List<? extends Shape> list = new ArrayList<Circle>();
list.add(new Square());
// element is a valid shape, but not a valid circle
// contract of the original list is broken.
如果您知道您只会使用一定数量的泛型,您可以存储每个表示的类并使用它以类型安全的方式转换列表。
class ListHolder<T> {
private final Class<T> clazz;
private final List<T> list;
public ListHolder(Class<T> clazz) {
this.clazz = clazz;
this.list = new ArrayList<T>();
}
public boolean isCircleList() {
return this.clazz == Circle.class;
}
public List<Circle> getCircleList() {
if (!isCircleList()) {
throw new IllegalStateException("list does not contain circles");
}
return (List<Circle>) list;
}
public boolean isRectangleList() {
return this.clazz == Rectangle.class;
}
public List<Rectangle> getRectangleList() {
if (!isRectangleList()) {
throw new IllegalStateException("list does not contain rectangles");
}
return (List<Rectangle>) list;
}
public static void main(String[] args) {
ListHolder<Rectangle> rectangleListHolder = new ListHolder<Rectangle>(Rectangle.class );
List<ListHolder<? extends Shape>> list = new ArrayList<ListHolder<? extends Shape>>();
list.add(rectangleListHolder);
ListHolder<? extends Shape> shapeWildCardList = list.get(0);
List<Rectangle> rectangles = shapeWildCardList.getRectangleList();
}
}