У меня есть массив целых чисел в Java, я хотел бы использовать только его часть. Я знаю, что в Python вы можете сделать что-то вроде этого массива [index:], и он возвращает массив из индекса. Возможно ли что-то подобное в Java.
У меня есть массив целых чисел в Java, я хотел бы использовать только его часть. Я знаю, что в Python вы можете сделать что-то вроде этого массива [index:], и он возвращает массив из индекса. Возможно ли что-то подобное в Java.
Ответы:
Длина массива в Java неизменна. Итак, вам нужно скопировать нужную часть в виде нового массива.
Используйте copyOfRange
метод из класса java.util.Arrays :
int[] newArray = Arrays.copyOfRange(oldArray, startIndex, endIndex);
startIndex - начальный индекс диапазона, который будет скопирован, включительно.
endIndex - окончательный индекс диапазона, который будет скопирован, исключительный. (Этот индекс может лежать вне массива)
Например:
//index 0 1 2 3 4
int[] arr = {10, 20, 30, 40, 50};
Arrays.copyOfRange(arr, 0, 2); // returns {10, 20}
Arrays.copyOfRange(arr, 1, 4); // returns {20, 30, 40}
Arrays.copyOfRange(arr, 2, arr.length); // returns {30, 40, 50} (length = 5)
endIndex
размер, превышающий размер массива, переданного в качестве первого аргумента. Итак, если вам нужна полная копия, создайте переменную, Arrays.copyOfRange(var, 0, var.length)
Arrays.copyOf(var, var.length)
Arrays.copyOfRange(Thread.currentThread().getStackTrace(),1,Short.MAX_VALUE)
ArrayIndexOutOfBoundsException
.
Да, вы можете использовать Arrays.copyOfRange
Это делает примерно то же самое (обратите внимание, что есть копия: вы не меняете исходный массив).
List
и a, subList
как указано в ответе @ K-bal.
Можешь попробовать:
System.arraycopy(sourceArray, 0, targetArray, 0, targetArray.length);// copies whole array
// copies elements 1 and 2 from sourceArray to targetArray
System.arraycopy(sourceArray, 1, targetArray, 0, 2);
См. Javadoc для системы .
Если вы используете Java 1.6 или выше, вы можете использовать Arrays.copyOfRange
для копирования части массива. От Javadoc:
Копирует указанный диапазон указанного массива в новый массив. Начальный индекс диапазона (от) должен лежать между нулем и
original.length
включительно. Значение вoriginal[from]
помещается в начальный элемент копии (еслиfrom == original.length
илиfrom == to
). Значения из последующих элементов в исходном массиве помещаются в последующие элементы в копии. Окончательный индекс range (to
), который должен быть больше или равенfrom
, может быть большеoriginal.length
, в этом случаеfalse
помещается во все элементы копии, индекс которых больше или равенoriginal.length - from
. Длина возвращаемого массива будетto - from
.
Вот простой пример :
/**
* @Program that Copies the specified range of the specified array into a new
* array.
* CopyofRange8Array.java
* Author:-RoseIndia Team
* Date:-15-May-2008
*/
import java.util.*;
public class CopyofRange8Array {
public static void main(String[] args) {
//creating a short array
Object T[]={"Rose","India","Net","Limited","Rohini"};
// //Copies the specified short array upto specified range,
Object T1[] = Arrays.copyOfRange(T, 1,5);
for (int i = 0; i < T1.length; i++)
//Displaying the Copied short array upto specified range
System.out.println(T1[i]);
}
}
Проверьте copyOfRange ; и пример:
int[] arr2 = Arrays.copyOfRange(arr,0,3);
Вы можете использовать что-то вроде этого: Arrays#copyOfRange
Вы можете использовать subList(int fromIndex, int toIndex)
метод для целых чисел arr, что-то вроде этого:
import java.util.ArrayList;
import java.util.List;
public class Main {
public static void main(String[] args) {
List<Integer> arr = new ArrayList<>();
arr.add(1);
arr.add(2);
arr.add(3);
arr.add(4);
List<Integer> partialArr = arr.subList(1, 3);
// print the subArr
for (Integer i: partialArr)
System.out.println(i + " ");
}
}
Выход будет: 2 3
.
Обратите внимание, что subList(int fromIndex, int toIndex)
метод выполняет минус 1 для 2-ой переменной, которую он получает (var2 - 1), я точно не знаю, почему, но именно это и происходит, возможно, чтобы уменьшить вероятность превышения размера массива.
Arrays.copyOfRange(Thread.currentThread().getStackTrace(),1,255)
поскольку вместо 255 я не могу использовать Integer.MAX_VALUE, в случае, если я не хочу получать реальную длину