Прямо сейчас у меня есть:
public <T> T[] toArray(T[] old) {
T[] arr = Arrays.copyOf(old, old.length + size());
int i = old.length;
for(E obj : this) {
arr[i] = old.getClass().getComponentType().cast(obj);
++i;
}
return arr;
}
(Обратите внимание, что это не соответствует контракту, как было указано axtavt.)
, где я получаю это предупреждение:
Type safety: Unchecked cast from capture#2-of ? to T
Это по-прежнему лучший / самый простой способ его реализации?Могу ли я как-то кодировать это без предупреждения?Как бы я реализовал это иначе?
Редактировать: Мое текущее решение.Во-первых, я действительно хотел, чтобы такого предупреждения не было в самом toArray
.Поэтому я кодировал эти маленькие вспомогательные функции ( читайте здесь для дальнейшего обсуждения):
@SuppressWarnings("unchecked") static <T> Class<? extends T> classOf(T obj) {
return (Class<? extends T>) obj.getClass();
}
@SuppressWarnings("unchecked") static <T> Class<? extends T> classOf(T[] array) {
return (Class<? extends T>) array.getClass().getComponentType();
}
@SuppressWarnings("unchecked") static <T> T[] newArray(Class<T> clazz, int size) {
return (T[]) Array.newInstance(clazz, size);
}
Теперь моя реализация toArray
выглядит следующим образом:
public <T> T[] toArray(T[] array) {
int size = size();
if (array.length < size) {
array = newArray(classOf(array), size);
} else if (array.length > size) {
array[size] = null;
}
int i = 0;
for (E e : this) {
array[i] = classOf(array).cast(e);
i++;
}
return array;
}