Как объявить и инициализировать массив в Java?
Вы можете использовать либо объявление массива, либо литерал массива (но только если вы сразу же объявляете и воздействуете на переменную, литералы массива нельзя использовать для повторного назначения массива).
Для примитивных типов:
int[] myIntArray = new int[3];
int[] myIntArray = {1, 2, 3};
int[] myIntArray = new int[]{1, 2, 3};
Для классов, например String
, это то же самое:
String[] myStringArray = new String[3];
String[] myStringArray = {"a", "b", "c"};
String[] myStringArray = new String[]{"a", "b", "c"};
Третий способ инициализации полезен, когда вы сначала объявляете массив, а затем инициализируете его. Актерский состав необходим здесь.
String[] myStringArray;
myStringArray = new String[]{"a", "b", "c"};
Существует два типа массива.
Синтаксис значений по умолчанию:
int[] num = new int[5];
Или (менее предпочтительный)
int num[] = new int[5];
Синтаксис с указанными значениями (инициализация переменной/поля):
int[] num = {1,2,3,4,5};
Или (менее предпочтительный)
int num[] = {1, 2, 3, 4, 5};
Примечание. Для удобства int [] num предпочтительнее, потому что в нем четко сказано, что вы говорите здесь о массиве. Иначе никакой разницы. Совсем нет.
int[][] num = new int[5][2];
или
int num[][] = new int[5][2];
или
int[] num[] = new int[5][2];
num[0][0]=1;
num[0][1]=2;
num[1][0]=1;
num[1][1]=2;
num[2][0]=1;
num[2][1]=2;
num[3][0]=1;
num[3][1]=2;
num[4][0]=1;
num[4][1]=2;
или
int[][] num={ {1,2}, {1,2}, {1,2}, {1,2}, {1,2} };
int[][] num = new int[5][];
num[0] = new int[1];
num[1] = new int[5];
num[2] = new int[2];
num[3] = new int[3];
Итак, здесь мы явно определяем столбцы.
Другой способ:
int[][] num={ {1}, {1,2}, {1,2,3,4,5}, {1,2}, {1,2,3} };
for (int i=0; i<(num.length); i++ ) {
for (int j=0;j<num[i].length;j++)
System.out.println(num[i][j]);
}
В качестве альтернативы:
for (int[] a : num) {
for (int i : a) {
System.out.println(i);
}
}
Рваные массивы - это многомерные массивы.
Для объяснения см. Подробные сведения о многомерных массивах в официальные руководства java
Type[] variableName = new Type[capacity];
Type[] variableName = {comma-delimited values};
Type variableName[] = new Type[capacity];
Type variableName[] = {comma-delimited values};
также действителен, но я предпочитаю скобки после типа, потому что легче видеть, что тип переменной на самом деле является массивом.
Ниже показано объявление массива, но массив не инициализирован:
int[] myIntArray = new int[3];
Ниже показано объявление, а также инициализация массива:
int[] myIntArray = {1,2,3};
Теперь следующее также показывает объявление, а также инициализацию массива:
int[] myIntArray = new int[]{1,2,3};
Но этот третий показывает свойство анонимного создания массива-объекта, которое указывается ссылочной переменной "myIntArray", поэтому, если мы пишем только "new int [] {1,2,3};" то это может быть анонимный массив-объект.
Если мы просто напишем:
int[] myIntArray;
это не объявление массива, но следующий оператор делает следующее выражение завершенным:
myIntArray=new int[3];
Я считаю полезным, если вы понимаете каждую часть:
Type[] name = new Type[5];
Type[]
- это тип переменной, называемой именем ( "имя" называется идентификатором). Литеральный "Тип" - это базовый тип, а скобки означают, что это тип массива этой базы. Типы массивов в свою очередь являются собственными, что позволяет создавать многомерные массивы типа Type[][]
(тип массива Type []). Ключевое слово new
говорит о распределении памяти для нового массива. Число между скобкой говорит о том, насколько большой будет новый массив и сколько памяти будет выделено. Например, если Java знает, что базовый тип Type
занимает 32 байта, и вам нужен массив размером 5, ему необходимо внутренне выделить 32 * 5 = 160 байт.
Вы также можете создавать массивы с уже имеющимися значениями, такими как
int[] name = {1, 2, 3, 4, 5};
который не только создает пустое пространство, но и заполняет его этими значениями. Java может сказать, что примитивы являются целыми числами и что их 5, поэтому размер массива может быть определен неявно.
int[] name = new int[5]
?
Кроме того, если вы хотите что-то более динамичное, есть интерфейс List. Это не будет работать, но более гибко:
List<String> listOfString = new ArrayList<String>();
listOfString.add("foo");
listOfString.add("bar");
String value = listOfString.get(0);
assertEquals( value, "foo" );
List
- универсальный класс, в качестве параметра он имеет тип, заключенный в <>
. Это помогает, потому что вам нужно определить универсальный тип только один раз, и затем вы можете использовать его с несколькими различными типами. Для более подробного объяснения посмотрите на docs.oracle.com/javase/tutorial/java/generics/types.html
В качестве альтернативы,
// Either method works
String arrayName[] = new String[10];
String[] arrayName = new String[10];
Объявляет массив с именем arrayName
размером 10 (у вас есть элементы с 0 по 9 для использования).
Существует два основных способа создания массива:
Этот, для пустого массива:
int[] array = new int[n]; // "n" being the number of spaces to allocate in the array
И этот, для инициализированного массива:
int[] array = {1,2,3,4 ...};
Вы также можете создавать многомерные массивы, например:
int[][] array2d = new int[x][y]; // "x" and "y" specify the dimensions
int[][] array2d = { {1,2,3 ...}, {4,5,6 ...} ...};
Возьмите примитивный тип int
, например. Существует несколько способов объявления и массив int
:
int[] i = new int[capacity];
int[] i = new int[] {value1, value2, value3, etc};
int[] i = {value1, value2, value3, etc};
где во всех этих случаях вы можете использовать int i[]
вместо int[] i
.
С отражением вы можете использовать (Type[]) Array.newInstance(Type.class, capacity);
Обратите внимание, что в параметрах метода ...
отображается variable arguments
. По сути, любое количество параметров в порядке. Это проще объяснить с помощью кода:
public static void varargs(int fixed1, String fixed2, int... varargs) {...}
...
varargs(0, "", 100); // fixed1 = 0, fixed2 = "", varargs = {100}
varargs(0, "", 100, 200); // fixed1 = 0, fixed2 = "", varargs = {100, 200};
Внутри метода varargs
рассматривается как нормальный int[]
. Type...
может использоваться только в параметрах метода, поэтому int... i = new int[] {}
не будет компилироваться.
Обратите внимание, что при передаче int[]
методу (или любому другому Type[]
) вы не можете использовать третий способ. В заявлении int[] i = *{a, b, c, d, etc}*
компилятор предполагает, что {...}
означает int[]
. Но это потому, что вы объявляете переменную. При передаче массива методу декларация должна быть либо new Type[capacity]
, либо new Type[] {...}
.
Многомерные массивы гораздо сложнее справиться. По существу, 2D-массив представляет собой массив массивов. int[][]
означает массив int[]
s. Ключ состоит в том, что если int[][]
объявлен как int[x][y]
, максимальный индекс равен i[x-1][y-1]
. По существу, прямоугольник int[3][5]
равен:
[0, 0] [1, 0] [2, 0]
[0, 1] [1, 1] [2, 1]
[0, 2] [1, 2] [2, 2]
[0, 3] [1, 3] [2, 3]
[0, 4] [1, 4] [2, 4]
Если вы хотите создавать массивы с использованием отражений, вы можете сделать вот так:
int size = 3;
int[] intArray = (int[]) Array.newInstance(int.class, size );
Объявление массива ссылок на объекты:
class Animal {}
class Horse extends Animal {
public static void main(String[] args) {
/*
* Array of Animal can hold Animal and Horse (all subtypes of Animal allowed)
*/
Animal[] a1 = new Animal[10];
a1[0] = new Animal();
a1[1] = new Horse();
/*
* Array of Animal can hold Animal and Horse and all subtype of Horse
*/
Animal[] a2 = new Horse[10];
a2[0] = new Animal();
a2[1] = new Horse();
/*
* Array of Horse can hold only Horse and its subtype (if any) and not
allowed supertype of Horse nor other subtype of Animal.
*/
Horse[] h1 = new Horse[10];
h1[0] = new Animal(); // Not allowed
h1[1] = new Horse();
/*
* This can not be declared.
*/
Horse[] h2 = new Animal[10]; // Not allowed
}
}
Используя различные IntStream.iterate
и IntStream.takeWhile
:
int[] a = IntStream.iterate(10, x -> x <= 100, x -> x + 10).toArray();
Out: [10, 20, 30, 40, 50, 60, 70, 80, 90, 100]
int[] b = IntStream.iterate(0, x -> x + 1).takeWhile(x -> x < 10).toArray();
Out: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
Использование локального ввода типа переменной:
var letters = new String[]{"A", "B", "C"};
Массив - это последовательный список элементов
int item = value;
int [] one_dimensional_array = { value, value, value, .., value };
int [][] two_dimensional_array =
{
{ value, value, value, .. value },
{ value, value, value, .. value },
.. .. .. ..
{ value, value, value, .. value }
};
Если это объект, то это же понятие
Object item = new Object();
Object [] one_dimensional_array = { new Object(), new Object(), .. new Object() };
Object [][] two_dimensional_array =
{
{ new Object(), new Object(), .. new Object() },
{ new Object(), new Object(), .. new Object() },
.. .. ..
{ new Object(), new Object(), .. new Object() }
};
В случае объектов вам нужно либо назначить его null
для инициализации с помощью new Type(..)
, классы, такие как String
и Integer
, являются особыми случаями, которые будут обрабатываться как следующие
String [] a = { "hello", "world" };
// is equivalent to
String [] a = { new String({'h','e','l','l','o'}), new String({'w','o','r','l','d'}) };
Integer [] b = { 1234, 5678 };
// is equivalent to
Integer [] b = { new Integer(1234), new Integer(5678) };
В общем случае вы можете создавать массивы, которые M
мерные
int [][]..[] array =
// ^ M times [] brackets
{{..{
// ^ M times { bracket
// this is array[0][0]..[0]
// ^ M times [0]
}}..}
// ^ M times } bracket
;
Стоит отметить, что создание размерного массива M
является дорогостоящим с точки зрения Space. Поскольку при создании массива M
с N
во всех измерениях общий размер массива больше, чем N^M
, так как каждый массив имеет ссылку, а в M-размерности есть (M -1) -мерный массив ссылок. Общий размер выглядит следующим образом
Space = N^M + N^(M-1) + N^(M-2) + .. + N^0
// ^ ^ array reference
// ^ actual data
В Java 8 вы можете использовать это.
String[] strs = IntStream.range(0, 15) // 15 is the size
.mapToObj(i -> Integer.toString(i))
.toArray(String[]::new);
Для создания массивов класса Objects вы можете использовать java.util.ArrayList
. для определения массива:
public ArrayList<ClassName> arrayName;
arrayName = new ArrayList<ClassName>();
Назначение значений массиву:
arrayName.add(new ClassName(class parameters go here);
Чтение из массива:
ClassName variableName = arrayName.get(index);
Примечание:
variableName
- это ссылка на массив, означающий, что манипулирование variableName
будет управлять arrayName
для циклов:
//repeats for every value in the array
for (ClassName variableName : arrayName){
}
//Note that using this for loop prevents you from editing arrayName
для цикла, который позволяет редактировать arrayName
(обычный для цикла):
for (int i = 0; i < arrayName.size(); i++){
//manipulate array here
}
Объявлять и инициализировать для Java 8 и более поздних версий. Создайте простой целочисленный массив:
int [] a1 = IntStream.range(1, 20).toArray();
System.out.println(Arrays.toString(a1));
// Output: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
Создайте случайный массив для целых чисел между [-50, 50] и для удвоений [0, 1E17]:
int [] a2 = new Random().ints(15, -50, 50).toArray();
double [] a3 = new Random().doubles(5, 0, 1e17).toArray();
Последовательность "Power-of-two":
double [] a4 = LongStream.range(0, 7).mapToDouble(i -> Math.pow(2, i)).toArray();
System.out.println(Arrays.toString(a4));
// Output: [1.0, 2.0, 4.0, 8.0, 16.0, 32.0, 64.0]
Для String [] вы должны указать конструктор:
String [] a5 = Stream.generate(()->"I will not squeak chalk").limit(5).toArray(String[]::new);
System.out.println(Arrays.toString(a5));
Многомерные массивы:
String [][] a6 = List.of(new String[]{"a", "b", "c"} , new String[]{"d", "e", "f", "g"})
.toArray(new String[0][]);
System.out.println(Arrays.deepToString(a6));
// Output: [[a, b, c], [d, e, f, g]]
Вы также можете сделать это с помощью java.util.Arrays
:
List<String> number = Arrays.asList("1", "2", "3");
Out: ["1", "2", "3"]
Этот довольно простой и понятный. Я не видел этого в других ответах, поэтому подумал, что смогу это добавить.
Другой способ объявить и инициализировать ArrayList:
private List<String> list = new ArrayList<String>(){{
add("e1");
add("e2");
}};
Здесь много ответов. Добавление нескольких хитрых способов создания массивов (с точки зрения экзамена это полезно знать)
объявить и определить массив
int intArray[] = new int[3];
это создаст массив длины 3. Поскольку он содержит тип примитива int, все значения по умолчанию равны 0. Например
intArray[3]; // will return 0
Использование квадратных скобок [] перед именем переменной
int[] intArray = new int[3];
intArray[0] = 1; // array content now {1,0,0}
Инициализируйте и предоставьте данные в массив
int[] intArray = new int[]{1,2,3};
на этот раз не нужно упоминать размер в скобке коробки. Даже простой вариант этого
int[] intArray = {1,2,3,4};
Массив длины 0
int[] intArray = new int[0];
intArray.length; // will return length 0
Аналогично для многомерных массивов
int intArray[][] = new int[2][3];
// This will create an array of length 2 and
//each element contains another array of length 3.
// { {0,0,0},{0,0,0} }
intArray.length; // will return 2
intArray[0].length; // will return 3
Использование скобок перед переменной
int[][] intArray = new int[2][3];
это абсолютно нормально, если вы положите один кронштейн коробки в конце
int[] intArray [] = new int[2][4];
int[] intArray[][] = new int[2][3][4]
Некоторые примеры
int [] intArray [] = new int[][] {{1,2,3},{4,5,6}};
int [] intArray1 [] = new int[][] {new int[] {1,2,3}, new int [] {4,5,6}};
int [] intArray2 [] = new int[][] {new int[] {1,2,3},{4,5,6}}
// All the 3 arrays assignments are valid
//Array looks like {{1,2,3},{4,5,6}}
Не обязательно, чтобы каждый внутренний элемент был одинакового размера.
int [][] intArray = new int[2][];
intArray[0] = {1,2,3};
intArray[1] = {4,5};
//array looks like {{1,2,3},{4,5}}
int[][] intArray = new int[][2] ; // this won't compile keep this in mind.
Вы должны убедиться, что, если вы используете вышеприведенный синтаксис, в прямом направлении вы должны указать значения в скобках. Иначе он не будет компилироваться. Некоторые примеры:
int [][][] intArray = new int[1][][];
int [][][] intArray = new int[1][2][];
int [][][] intArray = new int[1][2][3];
Другая важная особенность - ковариантный
Number[] numArray = {1,2,3,4}; // java.lang.Number
numArray[0] = new Float(1.5f); // java.lang.Float
numArray[1] = new Integer(1); // java.lang.Integer
//You can store a subclass object in an array that is declared
// to be of the type of its superclass.
// Here Number is the superclass for both Float and Integer.
Number num[] = new Float[5]; // this is also valid
IMP: Для ссылочных типов значение по умолчанию, сохраненное в массиве, равно нулю.
С выводом типа локальной переменной вы должны указать тип только один раз:
var values = new int[] { 1, 2, 3 };
или же
int[] values = { 1, 2, 3 }
int[] SingleDimensionalArray = new int[2]
int[][] MultiDimensionalArray = new int[3][4]
return {1,2,3}
выдает ошибку, аreturn new int[]{1,2,3}
работает нормально (при условии, конечно, что ваша функция возвращает целочисленный массив).