一、可變參數
- 可變參數顧名思義就是,編寫一個函數的時候,可以傳入一個或者多個參數
- 實際原理:根據傳入的參數類型以及個數,創建一個數組,用於存儲這些數據,在函數中調用的時候,也可以使用數組的形式調用,下面我們舉個例子
package com.newJava;
public class D152_VariableParameters {
public static void main(String[] args) {
System.out.println("打印出了");
printString();
printString("jsidofs"," josdfjs");
}
public static void printString(String... strings) {
if (strings != null) {
int size = strings.length;
for (int i=0; i<size; i++) {
System.out.println(strings[i]);
}
} else {
System.out.println("空參數也是可以的");
}
System.out.println("空數組");
}
}
- 從上面的實驗上來看,即使我們沒有傳入任何數據,函數依然會被調用,但是傳入的是一個空的數組,但不是一個null
- 一些規則:儘量不使用這種寫法,如果要使用的話,需要把可變參數放到參數列表的最後面,不能放到中間或者前面。在進行重載函數的編寫完之後,調用的時候要明確傳入參數的類型,不要引起混淆,比如
package com.newJava;
public class D152_2_ConfuseMethodAndInvoke {
public static void print(String... a) {
System.out.println(a[0]);
}
public static void print(int... b) {
System.out.println(b[1]);
}
public static void main(String[] args) {
try {
print(null);
} catch (Exception e) {
e.printStackTrace();
} finally {
print("jdisf", "jdisfod");
}
}
}
- 這樣重載函數會引起編譯器的混亂,不知道該如何重載函數。
二、多線程狀態圖
三、源碼:
- 歡迎關注微信公衆號:傅里葉變換,個人賬號,僅用於技術交流