本文轉載自:https://blog.csdn.net/augfun/article/details/82450506,爲方便自己學習故轉載,非常感謝作者的整理和總結
Java數組的定義和使用
Java 中定義數組的語法有兩種:
type arrayName[];
type[] arrayName;// 更符合java習慣
type 爲Java中的任意數據類型,包括基本類型和組合類型,arrayName爲數組名,必須是一個合法的標識符,[ ] 指明該變量是一個數組類型變量。例如:
int demoArray[];
int[] demoArray;
這兩種形式沒有區別,使用效果完全一樣,讀者可根據自己的編程習慣選擇。
與C、C++不同,Java在定義數組時並不爲數組元素分配內存,因此[ ]中無需指定數組元素的個數,即數組長度。而且對於如上定義的一個數組是不能訪問它的任何元素的,我們必須要爲它分配內存空間,這時要用到運算符new,其格式如下:
(java定義數組時不爲數組分配內存,故需要用new自行分配內存空間)
arrayName=new type[arraySize];
其中,arraySize 爲數組的長度,type 爲數組的類型。如:
demoArray=new int[3];
爲一個整型數組分配3個int 型整數所佔據的內存空間。
通常,你可以在定義的同時分配空間,語法爲:
type arrayName[] = new type[arraySize];
例如:
int demoArray[] = new int[3];
數組的初始化
你可以在聲明數組的同時進行初始化(靜態初始化),也可以在聲明以後進行初始化(動態初始化)。例如:
// 靜態初始化
// 靜態初始化的同時就爲數組元素分配空間並賦值
int intArray[] = {1,2,3,4};
String stringArray[] = {“微學苑”, “http://www.weixueyuan.net”, “一切編程語言都是紙老虎”};
// 動態初始化
float floatArray[] = new float[3];
floatArray[0] = 1.0f;
floatArray[1] = 132.63f;
floatArray[2] = 100F;
數組引用
可以通過下標來引用數組:
arrayName[index];
與C、C++不同,Java對數組元素要進行越界檢查以保證安全性。
每個數組都有一個length屬性來指明它的長度,例如 intArray.length 指明數組 intArray 的長度。
【示例】寫一段代碼,要求輸入任意5個整數,輸出它們的和。
import java.util.*;
public class Demo {
public static void main(String[] args){
int intArray[] = new int[5];
long total = 0;
int len = intArray.length;
// 給數組元素賦值
System.out.print("請輸入" + len + "個整數,以空格爲分隔:");
Scanner sc = new Scanner(System.in);
for(int i=0; i<len; i++){
intArray[i] = sc.nextInt();
}
// 計算數組元素的和
for(int i=0; i<len; i++){
total += intArray[i];
}
System.out.println("所有數組元素的和爲:" + total);
}
}
運行結果:
請輸入5個整數,以空格爲分隔:10 20 15 25 50
所有數組元素的和爲:120
**
Array工具類
**
數組的遍歷
實際開發中,經常需要遍歷數組以獲取數組中的每一個元素。最容易想到的方法是for循環,例如:
實際開發中,經常需要遍歷數組以獲取數組中的每一個元素。最容易想到的方法是for循環,例如:
int arrayDemo[] = {1, 2, 4, 7, 9, 192, 100};
for(int i=0,len=arrayDemo.length; i<len; i++){
System.out.println(arrayDemo[i] + ", ");
}
輸出結果:
1, 2, 4, 7, 9, 192, 100,
不過,Java提供了”增強版“的for循環,專門用來遍歷數組,語法爲:
(for-each循環)
for( arrayType varName: arrayName ){
// Some Code
}
arrayType 爲數組類型(也是數組元素的類型);varName 是用來保存當前元素的變量,每次循環它的值都會改變;arrayName 爲數組名稱。
每循環一次,就會獲取數組中下一個元素的值,保存到 varName 變量,直到數組結束。即,第一次循環 varName 的值爲第0個元素,第二次循環爲第1個元素…例如:
(用for-each循環代替for循環)
int[] a = {1, 2, 4, 7, 9, 192, 100};
for(int i: a){
System.out.println(i + ", ");
}
輸出結果與上面相同。
這種增強版的for循環也被稱爲”foreach循環“,它是普通for循環語句的特殊簡化版。所有的foreach循環都可以被改寫成for循環。
但是,如果你希望使用數組的索引,那麼增強版的 for 循環無法做到。
二維數組
二維數組的聲明、初始化和引用與一維數組相似:
int intArray[ ][ ] = { {1,2}, {2,3}, {4,5} };
int a[ ][ ] = new int[2][3];
a[0][0] = 12;
a[0][1] = 34;
// …
a[1][2] = 93;
Java語言中,由於把二維數組看作是數組的數組,數組空間不是連續分配的,所以不要求二維數組每一維的大小相同。例如:
int intArray[ ][ ] = { {1,2}, {2,3}, {3,4,5} };
int a[ ][ ] = new int[2][ ];
a[0] = new int[3];
a[1] = new int[5];
【示例】通過二維數組計算兩個矩陣的乘積。
public class Demo {
public static void main(String[] args){
// 第一個矩陣(動態初始化一個二維數組)
int a[][] = new int[2][3];
// 第二個矩陣(靜態初始化一個二維數組)
int b[][] = { {1,5,2,8}, {5,9,10,-3}, {2,7,-5,-18} };
// 結果矩陣
int c[][] = new int[2][4];
// 初始化第一個矩陣
for(int i=0; i<2; i++)
for(int j=0; j<3 ;j++)
a[i][j] = (i+1) * (j+2);
// 計算矩陣乘積
for (int i=0; i<2; i++){
for (int j=0; j<4; j++){
c[i][j]=0;
for(int k=0; k<3; k++)
c[i][j] += a[i][k] * b[k][j];
}
}
// 輸出結算結果
for(int i=0; i<2; i++){
for (int j=0; j<4; j++)
System.out.printf("%-5d", c[i][j]);
System.out.printlnwww.ymzxrj.com();
}
}
}
運行結果:
25 65 14 -65
50 130 28 -130
幾點說明:
上面講的是靜態數組。靜態數組一旦被聲明,它的容量就固定了,不容改變。所以在聲明數組時,一定要考慮數組的最大容量,防止容量不夠的現象。
如果想在運行程序時改變容量,就需要用到數組列表(ArrayList,也稱動態數組)或向量(Vector)。
正是由於靜態數組容量固定的缺點,實際開發中使用頻率不高,被 ArrayList 或 Vector 代替,因爲實際開發中經常需要向數組中添加或刪除元素,而它的容量不好預估。
以下轉自:https://blog.csdn.net/weixin_41547486/article/details/79684414
工具類Arrays
數組的工具類,這裏的方法都是靜態的
-
把數組轉換成字符串
-
對任意數組排序
-
對任意的數組做二分法的查找
-
把數組轉換成List
例子:
package cn.tx.set;
import java.util.Arrays;
import java.util.List;
public class ArraysDemo {
public static void main(String[] args) {
int[] arr ={12,123,55,6,88,99,555,8445};
//將數組轉換成字符串
arrayToString(arr);
Person[] p = {new Person(1,12, "李昆鵬"),new Person(2,12, "李昆鵬")};
arrayToString(p);
//對數組進行排序
//Arrays.sort(arr,1,3)對數組進行局部排序
arraySort(arr);
//對數組進行二分查找,前提必須排好升序
System.out.println(binarySearch(arr, 88));
// 把數組轉換成List集合
Integer[] arr1 = {6,12,123,555,666};
List<Integer> list = Arrays.asList(arr1);
System.out.println(list);
//從數組轉換過來的list不能添加和刪除,但是可以修改
//list.add(1231);
//list.remove(12);
list.set(2, 345);
System.out.println(list);
}
/**
* 將數組轉換成字符串
* @param array
*/
public static void arrayToString(int[] array) {
System.out.println(Arrays.toString(array));
}
/**
* 將Person類數組轉換成字符串
* @param array
*/
public static void arrayToString(Person[] array) {
System.out.println(Arrays.toString(array));
}
/**
* 對數組進行升序排序
* @param array
*/
public static void arraySort(int[] array) {
//對對象進行排序的時候依照對象的compareTo方法進行的
Arrays.sort(array);
arrayToString(array);
}
/**
* 使用二分查找法
*/
public staticint binarySearch(int[] arr,intval) {
return Arrays.binarySearch(arr, val);
}
}
結果:
[12, 123, 55, 6, 88,99, 555, 8445]
[Person [id=1,age=12, name=李昆鵬], Person [id=2, age=12, name=李昆鵬]]
[6, 12, 55, 88, 99,123, 555, 8445]
3
[6, 12, 123, 555,666]
[6, 12, 345, 555,666]