Я играю с некоторыми кодовыми катами и пытаюсь в то же время лучше понять дженерики java. У меня есть этот маленький метод, который печатает массивы так, как мне нравится их видеть, и у меня есть пара вспомогательных методов, которые принимают массив «вещей» и индекс и возвращают массив «вещей» выше или ниже индекса ( это алгоритм двоичного поиска).
Два вопроса,
# 1 Могу ли я избежать приведения к T в splitBottom и splitTop? Это не правильно, или я поступаю неправильно (не говорите мне использовать python или что-то в этом роде;;))
# 2 Нужно ли писать отдельные методы для работы с примитивными массивами или есть лучшее решение?
public class Util {
public static <T> void print(T[] array) {
System.out.print("{");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]);
if (i < array.length - 1) {
System.out.print(", ");
}
}
System.out.println("}");
}
public static <T> T[] splitTop(T[] array, int index) {
Object[] result = new Object[array.length - index - 1];
System.arraycopy(array, index + 1, result, 0, result.length);
return (T[]) result;
}
public static <T> T[] splitBottom(T[] array, int index) {
Object[] result = new Object[index];
System.arraycopy(array, 0, result, 0, index);
return (T[]) result;
}
public static void main(String[] args) {
Integer[] integerArray = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
print(integerArray);
print(splitBottom(integerArray, 3));
print(splitTop(integerArray, 3));
String[] stringArray = {"one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten"};
print(stringArray);
print(splitBottom(stringArray, 3));
print(splitTop(stringArray, 3));
int[] intArray = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
// ???
}
}