通用通配符有界类型与通用有界类型参数

时间:2015-06-14 23:26:56

标签: java oop generics bounded-wildcard bounded-types

在了解Java Generics的过程中,我遇到过这个问题:

public static <T extends Number> int sumListElems(List<T> list){
   int total = 0;
   for(Number n: list)
       total += n.intValue();
   return total;
}

假设我有以下方法添加List的元素,仅限于包含Number的列表。

但是这个代码与这个代码的区别是什么:

public static int sumListElems(List<? extends Number> list){
   int total = 0;
   for(Number n: list)
      total += n.intValue();
   return total;
}

它们都按预期编译和执行。这两者有什么区别?除了语法?我什么时候更喜欢使用通配符而不是前者?

嗯,是的,使用通配符方法,我无法在列表中添加除null之外的新元素,或者它不会编译。但除此之外呢?

1 个答案:

答案 0 :(得分:2)

在这种情况下没有区别。对于更复杂的签名,您可能需要重用已定义的类型,因此需要定义它。类似的东西:

public static <T extends Number> void foo(T bar, List<T> myList)...

这不仅保证barmyList的元素都扩展了Number,而且它们的类型相同。你无法用其他语法强制执行它。