回答:
配列宣言または配列リテラルを使用できます(ただし、変数を宣言してすぐに影響を与える場合のみ、配列リテラルを使用して配列を再割り当てすることはできません)。
プリミティブ型の場合:
int[] myIntArray = new int[3];
int[] myIntArray = {1, 2, 3};
int[] myIntArray = new int[]{1, 2, 3};
// Since Java 8. Doc of IntStream: https://docs.oracle.com/javase/8/docs/api/java/util/stream/IntStream.html
int [] myIntArray = IntStream.range(0, 100).toArray(); // From 0 to 99
int [] myIntArray = IntStream.rangeClosed(0, 100).toArray(); // From 0 to 100
int [] myIntArray = IntStream.of(12,25,36,85,28,96,47).toArray(); // The order is preserved.
int [] myIntArray = IntStream.of(12,25,36,85,28,96,47).sorted().toArray(); // Sort
たとえば、クラスの場合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"};
return {1,2,3}
エラーは発生return new int[]{1,2,3}
しますが、正常に機能します(もちろん、関数が整数配列を返すと仮定します)
配列には2つのタイプがあります。
デフォルト値の構文:
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[] a, b;
と同じではないことに注意してくださいint a[], b;
。後者の形式を使用すると、間違いが起こりやすくなります。
Javaで配列を宣言するには、さまざまな方法があります。
float floatArray[]; // Initialize later
int[] integerArray = new int[10];
String[] array = new String[] {"a", "b"};
詳細については、SunチュートリアルサイトとJavaDocを参照してください。
各部分を理解しておくと役に立ちます。
Type[] name = new Type[5];
Type[]
nameと呼ばれる変数のタイプです( "name"はidentifierと呼ばれます)。リテラルの「タイプ」はベースタイプであり、角かっこはこれがそのベースの配列タイプであることを意味します。配列型は順番に独自の型であり、(Type []の配列型)のような多次元配列を作成できます。キーワードは、新しい配列にメモリを割り当てることを示しています。括弧内の数字は、新しい配列の大きさと割り当てるメモリの量を示しています。たとえば、Javaが基本型が32バイトを取ることを知っていて、サイズ5の配列が必要な場合、内部的に32 * 5 = 160バイトを割り当てる必要があります。Type[][]
new
Type
次のように、すでにそこにある値で配列を作成することもできます。
int[] name = {1, 2, 3, 4, 5};
これは、空のスペースを作成するだけでなく、それらの値で埋めます。Javaは、プリミティブが整数であり、プリミティブが5つあることを認識できるため、配列のサイズを暗黙的に決定できます。
int[] name = new int[5]
か?
以下は、配列の宣言を示していますが、配列は初期化されていません。
int[] myIntArray = new int[3];
次に、配列の宣言と初期化を示します。
int[] myIntArray = {1,2,3};
ここで、以下は、配列の宣言と初期化も示しています。
int[] myIntArray = new int[]{1,2,3};
しかし、この3番目の例は、参照変数「myIntArray」によってポイントされる匿名の配列オブジェクト作成のプロパティを示しているため、「new int [] {1,2,3};」とだけ書くと、次に、これが匿名の配列オブジェクトを作成する方法です。
私たちが書くだけなら:
int[] myIntArray;
これは配列の宣言ではありませんが、次のステートメントは上記の宣言を完了させます。
myIntArray=new int[3];
または、
// Either method works
String arrayName[] = new String[10];
String[] arrayName = new String[10];
これはarrayName
、サイズ10 と呼ばれる配列を宣言します(使用する要素0〜9があります)。
また、よりダイナミックなものが必要な場合に備えて、Listインターフェイスがあります。これは同様に機能しませんが、より柔軟です。
List<String> listOfString = new ArrayList<String>();
listOfString.add("foo");
listOfString.add("bar");
String value = listOfString.get(0);
assertEquals( value, "foo" );
List
はジェネリッククラスであり、パラメータとして型があり、で囲まれてい<>
ます。これは、ジェネリック型を1回定義するだけで済み、それを複数の異なる型で使用できるため、役立ちます。詳細については、docs.oracle.com / javase / tutorial / java / generics / types.htmlを
配列を作成するには、主に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, etc}*
では、コンパイラはがを{...}
意味すると想定し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]
さまざまなIntStream.iterate
and 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 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
}
}
配列は項目の順次リストです
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
次元の配列を作成すると、スペースの点でコストがかかることに注意してください。すべての次元でM
次元配列を作成するN
場合N^M
、各配列には参照があるため、配列の合計サイズはより大きく、M次元には(M-1)次元の参照配列があります。合計サイズは以下の通りです
Space = N^M + N^(M-1) + N^(M-2) + .. + N^0
// ^ ^ array reference
// ^ actual data
クラスObjectの配列を作成するには、を使用できます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
編集できるforループarrayName
(従来のforループ):
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();
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]]
ArrayListを宣言して初期化する別の方法:
private List<String> list = new ArrayList<String>(){{
add("e1");
add("e2");
}};
ここにはたくさんの答えがあります。配列を作成するためのいくつかのトリッキーな方法を追加します(試験の観点から、これを知っておくのは良いことです)
配列を宣言して定義する
int intArray[] = new int[3];
これにより、長さ3の配列が作成されます。プリミティブ型intを保持しているため、すべての値はデフォルトで0に設定されています。例えば、
intArray[2]; // Will return 0
変数名の前に角括弧[]を使用する
int[] intArray = new int[3];
intArray[0] = 1; // Array content is 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
重要:参照される型の場合、配列に格納されているデフォルト値はnullです。
ローカル変数の型推論では、型を1回指定するだけで済みます。
var values = new int[] { 1, 2, 3 };
または
int[] values = { 1, 2, 3 }
var
。
var
openjdk.java.net/jeps/286
配列には2つの基本的なタイプがあります。
静的配列:固定サイズの配列(そのサイズは最初に宣言する必要があり、後で変更することはできません)
動的配列:サイズ制限は考慮されていません。(純粋な動的配列はJavaには存在しません。代わりに、リストを使用することをお勧めします)
Integer、string、floatなどの静的配列を宣言するには、次の宣言と初期化ステートメントを使用します。
int[] intArray = new int[10];
String[] intArray = new int[10];
float[] intArray = new int[10];
// here you have 10 index starting from 0 to 9
動的機能を使用するには、Listを使用する必要があります... Listは純粋な動的配列であり、最初にサイズを宣言する必要はありません。以下は、JAVAでリストを宣言する適切な方法です>
ArrayList<String> myArray = new ArrayList<String>();
myArray.add("Value 1: something");
myArray.add("Value 2: something more");
配列の宣言と初期化は非常に簡単です。たとえば、1、2、3、4、5の5つの整数要素を配列に保存するとします。次の方法で行うことができます。
a)
int[] a = new int[5];
または
b)
int[] a = {1, 2, 3, 4, 5};
したがって、基本的なパターンは、メソッドa)による初期化と宣言です。
datatype[] arrayname = new datatype[requiredarraysize];
datatype
小文字にする必要があります。
したがって、基本的なパターンはメソッドaによる初期化と宣言です。
文字列配列の場合:
String[] a = {"as", "asd", "ssd"};
文字配列の場合:
char[] a = {'a', 's', 'w'};
float doubleの場合、配列のフォーマットは整数と同じになります。
例えば:
double[] a = {1.2, 1.3, 12.3};
しかし、「メソッドa」で配列を宣言して初期化する場合は、手動で、またはループなどで値を入力する必要があります。
しかし、「方法b」でそれを行う場合、値を手動で入力する必要はありません。
配列には、配列の定義に応じて、プリミティブデータ型とクラスのオブジェクトを含めることができます。プリミティブデータ型の場合、実際の値は連続したメモリ位置に格納されます。クラスのオブジェクトの場合、実際のオブジェクトはヒープセグメントに格納されます。
1次元配列:
1次元配列宣言の一般的な形式は次のとおりです。
type var-name[];
OR
type[] var-name;
Javaでの配列のインスタンス化
var-name = new type [size];
例えば
int intArray[]; //declaring array
intArray = new int[20]; // allocating memory to array
// the below line is equals to line1 + line2
int[] intArray = new int[20]; // combining both statements in one
int[] intArray = new int[]{ 1,2,3,4,5,6,7,8,9,10 };
// accessing the elements of the specified array
for (int i = 0; i < intArray.length; i++)
System.out.println("Element at index " + i + " : "+ intArray[i]);
映画クラスの別の完全な例😋
public class A {
public static void main(String[] args) {
class Movie{
String movieName;
String genre;
String movieType;
String year;
String ageRating;
String rating;
public Movie(String [] str)
{
this.movieName = str[0];
this.genre = str[1];
this.movieType = str[2];
this.year = str[3];
this.ageRating = str[4];
this.rating = str[5];
}
}
String [] movieDetailArr = {"Inception", "Thriller", "MovieType", "2010", "13+", "10/10"};
Movie mv = new Movie(movieDetailArr);
System.out.println("Movie Name: "+ mv.movieName);
System.out.println("Movie genre: "+ mv.genre);
System.out.println("Movie type: "+ mv.movieType);
System.out.println("Movie year: "+ mv.year);
System.out.println("Movie age : "+ mv.ageRating);
System.out.println("Movie rating: "+ mv.rating);
}
}
int[] SingleDimensionalArray = new int[2]
int[][] MultiDimensionalArray = new int[3][4]