Java基礎05——方法詳解
阿新 • • 發佈:2022-04-07
什麼是方法
-
Java方法是語句的集合,他們在一起執行一個功能
- 方法是解決一類問題的步驟的有序組合
- 方法是包含於類或物件中
- 方法在程式中被建立,在其他地方被引用
-
設計方法的原則:設計方法是,最好保證方法的原子性,一個方法只完成1個功能,這樣有利於我們後期的擴充套件。方法採用駝峰命名規則
方法的定義及呼叫
定義
-
是一段用來完成特定功能的程式碼片段,一般情況下,定義一個方法包含以下語法:
-
方法包含一個方法頭和一個方法體:
-
修飾符:是可選的,告訴編譯器如何呼叫該方法。定義了該方法的訪問型別、
-
返回值型別:方法可能會有返回值。returnValueType是方法返回值的資料型別。有些方法執行所需的操作,但沒有返回值。這種情況下,returnValueType關鍵字是void
-
方法名:是方法的實際名稱。方法名和引數表共同構成方法簽名。
-
引數型別:引數像是一個佔位符。當方法被呼叫時,傳遞值給引數。這個值被稱為實參或變數。引數列表是指方法的引數型別、順序和引數的個數。引數是可選的,方法可以不包含任何引數。
- 形式引數:在方法被呼叫時用於接收外界輸入的資料
- 實參:呼叫方法時實際傳給方法的資料
-
方法體:方法體包含具體的語句,定義該方法的功能
-
結構:
修飾符 返回值型別 方法名(引數型別 引數名){ ... 方法體 ... return 返回值; }
-
呼叫
-
呼叫方法:物件名.方法名(實參列表)
-
Java支援兩種呼叫方法的方式,根據方法是否有返回值來選擇
-
當方法返回一個值的時候,方法通常被當作一個值。
eg:
int larger = max(30,40)
-
如果方法返回值時void,方法呼叫一定是一條語句。
System.out.println("Hello World!");
方法過載
- 過載就是在一個類中,有相同的函式名稱,但會形成不同的函式
- 方法過載的規則
- 方法名稱必須相同
- 引數列表必須不同
- 方法的返回型別可以相同也可以不同
- 僅僅返回型別不同不足以成為方法的過載
-
實現理論
- 方法名稱相同時,編譯器會根據呼叫方法的引數個數、引數型別等逐個去匹配,以選擇對應的方法,如果匹配失敗,則編譯器報錯
命令列傳參
-
有時候你希望執行一個程式的時候再傳遞給他訊息。這要靠傳遞命令列引數給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]); } } }
可變引數
-
在方法宣告中,在指定引數型別後加一個省略號(...)
-
一個方法中只能指定一個可變引數,它必須是方法的最後一個引數。任何普通的引數必須在它之前宣告
public class Demo05 { public static void main(String[] args) { printMax(34,3,3,2,56,56.5); 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("The max value is " + result); } }
遞迴
-
遞迴就是A方法呼叫A方法!就是自己呼叫自己
-
遞迴策略只需要少量的程式就可描述出解題過程所需要的多次重複計算,大大地減少了程式的程式碼量,遞迴的能力在於用有限的語句來定義物件的無限集合
-
遞迴結構包括了兩個部分:
- 遞迴頭:什麼時候不呼叫自身方法。如果沒有頭,將陷入死迴圈
- 遞迴體:什麼時候需要呼叫自身方法
-
Demo:n的階乘
public class Demo06 { // 5! public static void main(String[] args) { System.out.println(f(5)); } public static int f(int n){ if (n == 1){//遞迴頭 邊界條件 return 1; }else {// 遞迴體 return n*f(n - 1); } } }