在实现泛型方法时,我使用了以下语句:
@SuppressWarning({"unchecked"})
private static <T extends Comparable<T>> T[] merge(T[] arrayA, T[] arrayB) {
...
T[] result;
// This is the line that needs that gives warnings
result = (T[]) Array.newInstance(arrayA.getClass().getComponentType(), arrayA.length + arrayB.length);
...现在,许多编程资源指出,避免对未经检查的原始类型使用@SuppressWarning是一种很好的编程实践。但是,在这种情况下,我不知道如何在代码中处理此警告。在网上搜索在Java中实例化泛型类型的最佳实践并没有给出一种明确的方法。事实上,我发现的许多解决方案都不太理想。
在这段代码中,删除原始类型警告而不向方法添加@SuppressWarning的最佳方法是什么?我所做的是最好的方法吗?
发布于 2017-12-26 22:38:19
在某些情况下,您无法避免@SuppressWarnings。即使是标准的JDK类在处理泛型数组时也会使用@SuppressWarnings("unchecked")。
示例:
Arrays类:
@SuppressWarnings("unchecked")
public static <T> T[] copyOf(T[] original, int newLength) {
return (T[]) copyOf(original, newLength, original.getClass());
}说到Arrays.copyOf,您可以将该方法与System.arraycopy结合使用,而不是当前的逻辑:
private static <T extends Comparable<T>> T[] merge(T[] arrayA, T[] arrayB) {
T[] result = Arrays.copyOf (arrayA, arrayA.length+arrayB.length);
System.arraycopy (arrayB, 0, result, arrayA.length, arrayB.length);
return result;
}https://stackoverflow.com/questions/47979800
复制相似问题