freeCodeCamp/guide/chinese/java/arrays/index.md

5.6 KiB
Raw Blame History

title localeTitle
Arrays 数组

排列

Array是在顺序存储器地址中保存的具有相似数据类型允许数据类型形式的基元和引用的值或对象的集合。 Array用于存储类似数据类型的集合。 数组总是从索引0开始并实例化为一定数量的索引。 数组中的所有变量必须是同一类型,在实例化时声明。

句法:

dataType[] arrayName;   // preferred way 

这里, java datatype[]描述了在它之后声明的所有变量将被实例化为指定数据类型的数组。因此,如果我们想要实例化更多类似数据类型的数组,我们只需要在指定的java arrayName之后添加它们(不要忘记仅通过逗号分隔它们)。下一节将给出一个例子以供参考。

dataType arrayName[];  //  works but not preferred way 

这里, java datatype仅描述了属于该数据类型后所声明的变量。此外,变量名后面的java []描述变量是指定数据类型的数组(而不仅仅是该数据类型的值或对象)。因此,如果我们想要实例化更多相似数据类型的数组,我们将在已经指定的数组之后添加变量名称,用逗号分隔,每次我们必须在变量名后添加java [] ,否则变量将是实例化为普通的值存储变量(不是数组)。为了更好地理解,下一节将给出一个示例。

上述语法的代码片段:

double[] list1, list2; // preferred way 

上面的代码片段实例化了两个双重类型名称list1和list2的数组。

double list1[], list2; // works but not preferred way 

上面的代码片段是一个数组类型的数组double名为list1数据类型为double的简单变量名为list2不要与名称list2混淆。变量名称与变量类型无关)。

注意:样式double list[]不是首选因为它来自C / C ++语言并且在Java中被采用以适应C / C ++程序员。另外它更具可读性:你可以读到它是一个“双数组命名列表”而不是“一个双重调用列表是一个数组”

创建数组:

dataType[] arrayName = new dataType[arraySize]; 

上述语法的代码片段:

double[] List = new double[10]; 

另一种创建数组的方法:

dataType[] arrayName = {value_0, value_1, ..., value_k}; 

上述语法的代码片段:

double[] list = {1, 2, 3, 4}; 
 
 The code above is equivalent to: 
 double[] list = new double[4]; 
 *IMPORTANT NOTE: Please note the difference between the types of brackets 
 that are used to represent arrays in two different ways. 

访问数组:

arrayName[index]; // gives you the value at the specified index 

上述语法的代码片段:

System.out.println(list[1]); 

输出:

2.0 

修改数组:

arrayName[index] = value; 

注意:初始化后,您无法更改阵列的大小或类型。 注意:您可以像这样重置数组

arrayName = new dataType[] {value1, value2, value3}; 

数组大小:

可以使用“length属性”找到数组中的元素数量。这里应该注意 java length是每个数组的属性 ,即存储变量长度的变量名。不能将它与数组方法混淆因为该名称与String类对应的java length()方法相同。

int[] a = {4, 5, 6, 7, 8}; // declare array 
 System.out.println(a.length); //prints 5 

上述语法的代码片段:

list[1] = 3; // now, if you access the array like above, it will output 3 rather than 2 

代码示例:

int[] a = {4, 5, 6, 7, 8}; // declare array 
 for (int i = 0; i < a.length; i++){ // loop goes through each index 
    System.out.println(a[i]); // prints the array 
 } 

输出:

    4 
    5 
    6 
    7 
    8 

多维数组

二维数组2D数组可以被认为是具有行和列的表。虽然这种表示只是一种可视化阵列的方法可以更好地解决问题。这些值实际上仅存储在顺序存储器地址中。

int M = 5; 
 int N = 5; 
 double[][] a = new double [M][N]; //M = rows N = columns 
 for(int i = 0; i < M; i++) { 
    for (int j = 0; j < N; j++) { 
        //Do something here at index 
    } 
 } 

这个循环将执行M ^ N次并将构建此

0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4

类似地也可以制作3D阵列。它可以被视为长方体而不是矩形如上所示被分成较小的立方体每个立方体存储一些值。它可以初始化如下

int a=2, b=3, c=4; 
 int[][][] a=new int[a][b][c]; 

以类似的方式,可以是他/她希望的多个维度的阵列但是难以以特定方式可视化多于3个维度的阵列。

锯齿状阵列

锯齿状数组是多维数组,具有一定数量的行但具有不同数量的列。锯齿状数组用于节省阵列的内存使用。这是一个代码示例:

int[][] array = new int[5][]; //initialize a 2D array with 5 rows 
 array[0] = new int[1]; //creates 1 column for first row 
 array[1] = new int[2]; //creates 2 columns for second row 
 array[2] = new int[5]; //creates 5 columns for third row 
 array[3] = new int[5]; //creates 5 columns for fourth row 
 array[4] = new int[5]; //creates 5 columns for fifth row 

输出:

0
0 | 1
0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4
0 | 1 | 2 | 3 | 4

更多信息: