Java で配列を宣言して初期化するにはどうすればよいですか?
質問
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"};
3番目の初期化方法は、最初に配列を宣言してから初期化するときに役立ちます。ここでキャストが必要です。
String[] myStringArray;
myStringArray = new String[]{"a", "b", "c"};
他のヒント
配列には2つのタイプがあります。
1次元配列
デフォルト値の構文:
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チュートリアル にある多次元配列の詳細を参照してください。 p>
Type[] variableName = new Type[capacity];
Type[] variableName = {comma-delimited values};
Type variableName[] = new Type[capacity];
Type variableName[] = {comma-delimited values};
も有効ですが、変数の型が実際に配列であることがわかりやすいため、型の後に角括弧を使用します。
Javaで配列を宣言するには、さまざまな方法があります。
float floatArray[]; // Initialize later
int[] integerArray = new int[10];
String[] array = new String[] {"a", "b"};
詳細については、 Sunのチュートリアルサイトおよび JavaDoc 。
以下は配列の宣言を示していますが、配列は初期化されていません:
int[] myIntArray = new int[3];
以下は、宣言と配列の初期化を示しています。
int[] myIntArray = {1,2,3};
今、以下は配列の宣言と初期化も示しています:
int[] myIntArray = new int[]{1,2,3};
しかし、この3つ目は、参照変数&quot; myIntArray&quot;が指す匿名配列オブジェクト作成のプロパティを示しています。したがって、&quot; new int [] {1,2,3};&quot;これが匿名配列オブジェクトの作成方法です。
書くだけの場合:
int[] myIntArray;
これは配列の宣言ではありませんが、次のステートメントは上記の宣言を完了させます。
myIntArray=new int[3];
各部分を理解しておくと役立つと思います:
Type[] name = new Type[5];
Type []
は、名前と呼ばれる変数の type です(&quot; name&quot;は identifier )。リテラル&quot; Type&quot;はベース型であり、括弧はこれがそのベースの配列型であることを意味します。配列型は、独自の型であり、 Type [] []
(Type []の配列型)のような多次元配列を作成できます。キーワード new
は、新しい配列にメモリを割り当てることを示しています。括弧内の数字は、新しい配列の大きさと割り当てるメモリ量を示しています。たとえば、Javaがベースタイプ Type
が32バイトを使用することを認識しており、サイズ5の配列が必要な場合、32 * 5 = 160バイトを内部的に割り当てる必要があります。
次のような値が既に存在する配列を作成することもできます
int[] name = {1, 2, 3, 4, 5};
これは、空のスペースを作成するだけでなく、それらの値で埋めます。 Javaは、プリミティブが整数であり、5つあることを認識できるため、配列のサイズは暗黙的に決定できます。
あるいは、
// Either method works
String arrayName[] = new String[10];
String[] arrayName = new String[10];
サイズ10の arrayName
という配列を宣言します(使用する要素0〜9があります)。
また、もっと動的なものが必要な場合のために、Listインターフェースがあります。これは同様に機能しませんが、より柔軟です:
List<String> listOfString = new ArrayList<String>();
listOfString.add("foo");
listOfString.add("bar");
String value = listOfString.get(0);
assertEquals( value, "foo" );
配列を作成する主な方法は2つあります:
空の配列の場合:
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 []
)に渡す場合、3番目の方法は使用できないことに注意してください。ステートメント int [] i = * {a、b、c、dなど} *
では、コンパイラは {...}
が int []
。しかし、それは変数を宣言しているからです。配列をメソッドに渡すとき、宣言は new Type [capacity]
または new Type [] {...}
でなければなりません。
多次元配列
多次元配列の処理ははるかに困難です。基本的に、2D配列は配列の配列です。 int [] []
は、 int []
の配列を意味します。重要なのは、 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
}
}
Java9では
異なるものを使用する 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]
Java10では
を使用して、 ローカル変数の型推論:
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
に割り当てて、 String
などのクラスの new Type(..)
を使用して初期化する必要があります>および 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
次元配列を作成すると、スペースの点でコストが高くなることに注意してください。すべての次元で N
を使用して M
次元配列を作成すると、配列の合計サイズは N ^ M
よりも大きくなるため、各配列には参照があり、M次元には(M-1)次元の参照配列があります。合計サイズは次のとおりです
Space = N^M + N^(M-1) + N^(M-2) + .. + N^0
// ^ ^ array reference
// ^ actual data
クラスオブジェクトの配列を作成するには、 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
forループ:
//repeats for every value in the array
for (ClassName variableName : arrayName){
}
//Note that using this for loop prevents you from editing arrayName
arrayName
を編集できるforループ(従来のforループ):
for (int i = 0; i < arrayName.size(); i++){
//manipulate array here
}
Java 8では、このように使用できます。
String[] strs = IntStream.range(0, 15) // 15 is the size
.mapToObj(i -> Integer.toString(i))
.toArray(String[]::new);
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]の整数とdouble [0、1E17]のランダム配列を作成します:
int [] a2 = new Random().ints(15, -50, 50).toArray();
double [] a3 = new Random().doubles(5, 0, 1e17).toArray();
2のべき乗シーケンス:
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");
}};
ローカル変数の型推論では、型を1回指定するだけです。
var values = new int[] { 1, 2, 3 };
または
int[] values = { 1, 2, 3 }
多くの回答がここにあります。配列を作成するためのいくつかのトリッキーな方法を追加します(試験の観点から、これを知っておくとよいでしょう)
-
配列の宣言と定義
int intArray[] = new int[3];
これは長さ3の配列を作成します。プリミティブ型intを保持するため、デフォルトですべての値が0に設定されます。たとえば
intArray[2]; // 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]; int length = 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} } int lenght1 = intArray.length; // will return 2 int length2 = intArray[0].length; // will return 3
変数の前のボックスブラケットの使用
int[][] intArray = new int[2][3];
最後にボックスブラケットを1つ置くと、まったく問題ありません
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:参照型の場合、配列に保存されるデフォルト値はnullです。
配列の宣言: int [] arr;
配列の初期化: int [] arr = new int [10];
10は、配列で許可される要素の数を表します
多次元配列の宣言: int [] [] arr;
多次元配列の初期化: int [] [] arr = new int [10] [17];
10行17列、170要素。10の17が170であるため。
配列の初期化とは、配列のサイズを指定することです。
int[] SingleDimensionalArray = new int[2]
int[][] MultiDimensionalArray = new int[3][4]