1. 程式人生 > 其它 >Java方法詳解——基礎階段

Java方法詳解——基礎階段

Java方法詳解——基礎階段

1. 何謂方法

  • System.out.println():類.物件.方法

  • Java方法是語句的集合,它們在一起執行一個功能

    • 方法是解決一類問題的步驟的有序組合
    • 方法包含於類或物件中
    • 方法在程式中被建立,在其他地方被引用
  • 設計方法的原則:最好保持方法的原子性就是一個方法只完成1個功能,有利於後續的拓展

  • 命名規則:首字母小寫+駝峰規則

2. 方法的定義及呼叫

  • 方法的定義:類似於其他語言的函式,是一段用來完成特定功能的程式碼片段,一般情況下一個方法包含以下語法:

    • 方法包含一個方法頭和一個方法體。下面是方法的所有部分:
      • 修飾符
      • 返回值型別:沒有返回值是設為void
      • 方法名
      • 引數型別:引數像一個佔位符
        • 形式引數
        • 實參
      • 方法體
    修飾符 返回值型別 方法名(引數型別 引數名){
        ...
        方法體
        ...
        return 返回值;
    }
    
  • 方法呼叫

    • 呼叫方法:物件名.方法名(實參列表)

    • Java支援兩種方法的方式,根據是否返回值來選擇

      • 當方法返回一個值的時候,方法呼叫通常被當作一個值

        int large = max(30,40);
        
      • 如果方法返回值是void,方法呼叫一定是一條語句

        System.out.println("Hello World!")
        
  • 值傳遞和引用傳遞(Java都是值傳遞)

3. 方法過載

  • 過載就是在一個類中,有相同的函式名稱,但是形參不同的函式。(名字相同,引數不同,同名不同參)

    public static int max(int num1, int num2){...}
    public static double max(double num1, double num2){...}
    public static int max(int num1, int num2, int num3){...}
    
  • 規則

    • 方法名稱必須相同
    • 引數列表必須不同(引數個數、引數型別、引數排列數序等)
    • 方法的返回型別可以相同也可以不同
    • 僅僅返回型別不同不足以成為方法的過載
  • 實現理論:

    • 方法名稱相同時,編譯器會根據呼叫方法的引數個數、型別等去逐個匹配,以選擇對應方法,如果匹配失敗,則編譯器報錯

4. 命令列傳參

  • 有時候需要在執行一個程式時再傳遞給它訊息。這要靠傳遞命令列引數給main()函式實現。

5. 可變引數(不定項引數)

  • JDK1.5 開始,Java支援傳遞同類型的可變引數給一個方法
  • 在方法宣告中,指定引數型別後加一個省略號(...)
  • 一個方法中只能制定一個可變引數,它必須是方法的最後一個引數。任何普通引數必須在它之前宣告。
public class Demo04 {
    public static void main(String[] args) {
        // 呼叫可變引數的方法
        printMax(34, 3,4 ,1, 423);
        printMax(new double[]{1,2,3});

    }

    public static void printMax(double... numbers){
        if (numbers.length == 0){
            System.out.println("No argument passed");
            return;
        }

        double result = numbers[0];

        // 排序!
        for (int i = 1; i < numbers.length; i++) {
            if (numbers[i] > result){
                result = numbers[i];
            }
        }
        System.out.println("最大值為:"+ result);
    }

}

6. 遞迴

  • 遞迴就是:A方法呼叫A方法,自己呼叫自己
  • 利用遞迴可以用簡單的程式來解決一些複雜的問題
  • 遞迴結構包括兩個部分:
    • 遞迴頭:什麼時候不呼叫自身方法。如果沒有頭,將陷入死迴圈
    • 遞迴體:什麼時候需要呼叫自身方法