1. 程式人生 > 實用技巧 >java學習筆記 方法篇01

java學習筆記 方法篇01

Java 方法(C語言的函式)第一篇

何為方法

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

    • 方法是解決一類問題的步驟的有序組合

    • 方法包含於類或物件中

    • 方法在程式中被建立,在其他地方被引用

  • 設計方法的原則:方法的本意是功能塊,就是實現某個功能的語句塊的集合。我們設計方法的時候,最好保持方法的原子性,就是一個方法只完成1個功能,這樣利於我們後期的擴充套件。

方法的定義

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

  • 方法包含一個方法頭和一個方法體。下面是一個方法的所有部分:

    • 修飾符:修飾符,這是可選的,告訴編輯器如何呼叫該方法。定義了該方法的訪問型別。

    • 返回值型別:方法可能會有返回值,returnValueType 是方法返回值的資料型別。有些方法執行所需的操作,但沒有返回值。在這種情況下,returnValurType 是關鍵字void。

    • 方法名:是方法的實際名稱。方法名和引數表共同構成方法簽名。

    • 引數型別:引數像是一個佔位符。當方法被呼叫時,傳遞值給引數。這個值被稱為實參或變數。引數列表是指方法的引數型別,順序和引數的個數。引數是可選的,方法可以不包含任何引數。

      • 形式引數:在方法被呼叫時用於接收外界輸入的資料。

      • 實際引數:呼叫方法時實際傳給方法的資料

    • 方法體:方法體包含具體的語句,定義該方法的功能。

    修飾符 返回值型別 方法名(引數型別 引數名){
    ...
    方法體
    ...
    return 返回值;
    }

形參:在定義方法的時候定義的,用來描述方法的作用的

實參:在呼叫方法的時候傳入的實際數值

例如:

public class Demo {
public static void main(String[] args) {
//下面的1和2是實參
System.out.println(add(1, 2));
}

//下面的a和b是形參
public static int add(int a, int b) {
return a + b;
}
}

return 還可以用來終止方法

方法呼叫

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

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

  • 當方法返回一個值的時候,方法呼叫通常被當做一個值。例如:

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

    System.out.println("Hello,kuangshen!");
  • 課後拓展瞭解:值傳遞(Java) 和 引用傳遞

方法的過載

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

  • 方法的過載的規則:

    • 方法名稱必須相同。

    • 引數列表必須不同 (個數不同 、或型別不同、引數排列順序不同等)。

    • 方法的返回型別可以相同也可以不相同。

    • 僅僅返回型別不同不足以成為方法的過載。

  • 實現理論:

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

命令列傳參

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

    public class CommandLine{
    public static void main(String args[]){
    for(int i=0; i<args.length; i++){
    System.out.println("args[" + i + "]" + args[i]);
    }
    }
    }

使用命令列執行程式的時候,編譯過程(javac)可以在 .java 檔案下執行,但是執行class檔案的時候需要加上包名了,即執行class檔案的時候需要到src檔案下執行

可變引數(不定項引數)

  • JDK 1.5 開始,Java支援傳遞 同類型的可變引數 給一個方法。

  • 在方法宣告中,在指定引數型別後加上一個省略號 (...) 。

  • 一個方法中只能指定一個可變引數,它必須是方法的最後一個引數。任何普通的引數必須在它之前宣告。

    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("The max value is" + result);
    }

可變引數實際上就是傳遞陣列用的引數

遞迴

  • 遞迴就是 A 方法呼叫 A 方法。就是自己呼叫自己

  • 利用遞迴可以用簡單的程式來解決一些複雜的問題。它通常把一個大型複雜的問題層層轉化為一個與原問題相似的 規模較小的 問題來求解,遞迴策略只需少量的程式就可描述出解題過程所需要的多次重複計算,大大減少了程式的程式碼量。遞迴的能力在於用有限的語句來定義物件的無限集合。

  • 遞迴結構包括兩個部分:

    • 遞迴頭:什麼時候不呼叫自身方法。如果沒有頭,將陷入死迴圈。

    • 遞迴體:什麼時候需要呼叫自身方法。

因為遞迴會耗費大量的空間和時間,所以能不用遞迴就不用遞迴