我已将Netbean设置为在我的Java代码中显示未经检查的警告,但我无法理解以下行中的错误:
private List<String> cocNumbers;
private List<String> vatNumbers;
private List<String> ibans;
private List<String> banks;
...
List<List<String>> combinations = Utils.createCombinations(cocNumbers, vatNumbers, ibans);
给予:
[未选中]为List类型的varargs参数创建未选中的泛型数组
方法来源:
/**
* Returns a list of all possible combinations of the entered array of lists.
*
* Example: [["A", "B"], ["0", "1", "2"]]
* Returns: [["A", "0"], ["A", "1"], ["A", "2"], ["B", "0"], ["B", "1"], ["B", "2"]]
*
* @param <T> The type parameter
* @param elements An array of lists
* @return All possible combinations of the entered lists
*/
public static <T> List<List<T>> createCombinations(List<T>... elements) {
List<List<T>> returnLists = new ArrayList<>();
int[] indices = new int[elements.length];
for (int i = 0; i < indices.length; i++) {
indices[i] = 0;
}
returnLists.add(generateCombination(indices, elements));
while (returnLists.size() < countCombinations(elements)) {
gotoNextIndex(indices, elements);
returnLists.add(generateCombination(indices, elements));
}
return returnLists;
}
到底出了什么问题,我该如何修复它,因为我认为在代码中留下未经检查的警告不是一个好主意?
忘了提,但我用的是Java7。
编辑:我现在还看到该方法具有以下内容:
[unchecked] Possible heap pollution from parameterized vararg type List<T>
where T is a type-variable:
T extends Object declared in method <T>createCombinations(List<T>...)
正如上面提到的janoh. janoh,Java中的varargs只是数组的语法糖,加上在调用站点隐式创建数组。所以
List<List<String>> combinations =
Utils.createCombinations(cocNumbers, vatNumbers, ibans);
实际上是
List<List<String>> combinations =
Utils.createCombinations(new List<String>[]{cocNumbers, vatNumbers, ibans});
但是你可能知道,新列表
无论如何,编译器仍然创建数组,而不是失败。它做了类似的事情:
List<List<String>> combinations =
Utils.createCombinations((List<String>[])new List<?>[]{cocNumbers, vatNumbers, ibans});
这可能不安全,但不一定不安全。大多数varargs方法只是简单地迭代varargs元素并读取它们。在这种情况下,它不关心数组的运行时类型。您的方法就是这种情况。由于您在Java7上,您应该将@SafeVarargs
注释添加到您的方法中,您将不会再收到此警告。此注释基本上说,此方法只关心元素的类型,而不是数组的类型。
但是,有一些varargs方法确实使用了数组的运行时类型。在这种情况下,它可能不安全。这就是为什么有警告。
因为java编译器对varargs使用隐式数组创建,java不允许创建泛型数组(因为类型参数不可再现)。
下面的代码是正确的(数组允许这些操作),因此需要未经检查的警告:
public static <T> List<List<T>> createCombinations(List<T> ... lists) {
((Object[]) lists)[0] = new ArrayList<Integer>();
// place your code here
}
在这里看到全面的解释