я столкнулся с этим сценарием при выполнении рефакторинга, поэтому мне было интересно, существуют ли какие-либо различия между ними обоими?
Например:
import java.util.List;
import java.lang.reflect.Array;
public Object[] toArray(List<Foo> foos) {
Object array = Array.newInstance(Foo.class, foos.size())
int i = 0;
for(Foo foo : foos) {
Array.set(array, i, foo.getSomeProperty);
i++;
}
return (Object[]) array;
}
Что касается другой руки
import java.util.List;
public Object[] toArray(List<Foo> foos) {
Object[] array = new Object[foos.size()];
int i = 0;
for(Foo foo : foos) {
array[i] = foo.getSomeProperty;
i++;
}
return array;
}
Есть ли реальная разница между ними? Мой вопрос касается как части инициализации, так и установки значения one
При выполнении тестов результаты всегда одинаковы между ними




С помощью Arrays.newInstance вы можете создать общий массив типа, который вы не знаете во время объявления. тем самым вы избегаете неприятного объявления Object[], которое имеет решающее значение для безопасности типов.
Для вашего примера я мог бы также написать
array[i]=new Bar();
См. этот пост это здесь.