動態初始化: 數組初始化時,程序員只指定數組的長度,由系統為每個元素賦初值。
數組是否必須初始化
對於這個問題,關鍵在於要弄清楚數組變量和數組對象的差別。數組變量是存放在棧內存中的,數組對象是存放在堆內存中的。數組變量只是一個引用變量,他能夠指向實際的數組對象。
所謂的數組初始化並非對數組變量初始化,而是對數組對象進行初始化。
定義數組
方式1(推薦,更能表明數組類型) type[] 變量名 = new type[數組中元素的個數]; 比如:
int[] a = new int[10];
數組名,也即引用a,指向數組元素的首地址。
方式2(同C語言)
type變量名[] = new type[數組中元素的個數];
如:
int a[] = new int[10];
方式3 定義時直接初始化
type[] 變量名 = new type[]{逗號分隔的初始化值};
其中紅色部分可省略,所以又有兩種:
int[] a = {1,2,3,4};
int[] a = new int[]{1,2,3,4};
其中int[] a = new int[]{1,2,3,4};的第二個方括號中不能加上數組長度,因為元素個數是由后面花括號的內容決定的。
1.
利用Arrays庫中的sort方法對數組排序
package day1;
import java.util.*;
public class Arraysort {
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
int a[]=new int[5];
for (int i=0;i<a.length;i++) {
System.out.println("請輸入第"+(i+1)+"位學員的成績");
a[i]=input.nextInt();
}
System.out.println("您輸入的分數數據排序前為:");
for(int i=0;i<a.length;i++) {
System.out.print(a[i]+"\t");
}
Arrays.sort(a);
System.out.println("您輸入排序后的數列為:");
for(int i=0;i<a.length;i++) {
System.out.print(a[i]+"\t");
}
}
}
二維數組基礎
基本的定義方式有兩種形式,如:
type[][] [][]i = new type[2][3]//推薦使用
type i[][] = new type[2][3];
如下程序:
public class ArrayTest3
{
public static void main(String[] args)
{
int[][] i = new int[2][3];
System.out.println("Is i an Object? "
+ (i instanceof Object));
System.out.println("Is i[0] an int[]? "
+ (i[0] instanceof int[]));
}
}
輸出結果為兩個true