一、可變參數簡介
在不確定參數的個數時,可以使用可變的參數列表。
1. 語法:
參數類型...(三個點)
例如: void printArray(Object...)
注意: 每個方法最多只有一個可變參數,因為:可變參數必須是方法的最后一個參數
2. 可變參數的類型
可變參數可以設置為任意類型:引用類型,基本類型;當然也會進行類型檢查的;
3. 參數的個數:
- 0個參數
- 1個參數: 如果是數組,那么就直接將這個數組作為參數傳進方法里面,不再填充新的數組;
- 多個參數: 參數可以是數組,也可以是單個變量、常量;但是這時候會,將這些參數填充進新的數組里面,再將這個數組,傳進方法里面;
4. 可變參數的使用
可變參數完全可以當作一個數組來使用,或者說,本質上可變參數就是一個數組(下面詳細介紹)。所以,數組擁有的方法、屬性,可變參數一樣擁有。
public void varArgMethod(int b,int... arr) {
//和數組一樣,擁有屬性length
int lenth = arr.length;
//索引遍歷
for(int i=0;i<arr.length;i++) {
System.out.println(arr[i]);
}
//forEach循環遍歷
for(int ele:arr) {
System.out.println(ele);
}
}
上面的例子中,可變參數的使用跟數組的使用是完全一樣,也就是說,可變參數是可以等價成數組的
5. 可變參數的方法重載
可變參數列表的方法的重載不同於普通方法: 無法僅通過改變 可變參數的類型,來重載方法。
如:varArray(int... a)
、varArray(Object... a)
,這兩個方法在調用時會出錯,方法重載失敗。
二、 深入分析可變參數的原理
前面已經很詳細地介紹了可變參數的各個方面。這一小節將深入去了解可變參數的實現原理,特別是為什么可變參數的使用與數組是一樣的。
看下面一個簡單的例子:
public class MyTest{
public static void main(String[] args) {
int a = 100;
varArgMethod(5, 7,8,9,10,a);
}
public static void varArgMethod(int b,int... arr) {
//索引遍歷
for(int i=0;i<arr.length;i++) {
System.out.println(arr[i]);
}
}
}
例子很簡單,為了了解編譯器是怎么處理的,我們用jad對上面例子的class文件進行反編譯:
public class MyTest {
public static void main(String args[]) {
int a = 100;
varArgMethod(5, new int[]{7, 8, 9, 10, a});//參數列表被編譯器處理成了一個int[]數組
}
public static transient void varArgMethod(int b, int arr[]) { //形參被編譯器處理成數組
for (int i = 0; i < arr.length; i++)
System.out.println(arr[i]);
}
}
從反編譯的結果可以看出,編譯器不僅將可變參數處理成數組varArgMethod(int b, int arr[])
,還處理了調用可變參數方法處的參數列表,把參數列表封裝進一個數組varArgMethod(5, new int[]{7, 8, 9, 10, a})
。
現在看來,可變參數列表並沒有多神奇,只不過是將程序員做的工作簡化了,交給了編譯器來處理。最后,可變參數的使用和數組一樣也就不出奇了,因為可變參數最后還是被編譯器處理成了數組,可變參數就是數組。