MyBatis學習04
阿新 • • 發佈:2020-11-30
何為方法?
Java方法是語句的集合,它們在一起執行一個功能。
- 方法是解決一類問題的步驟的有序組合
- 方法包含於類或物件中
- 方法在程式中被建立,在其他地方被引用
設計方法的原則:方法的本意是功能塊,就是實現某個功能的語句塊的集合,我們設計方法的時候,最好保持方法的原子性,就是一個方法只完成一個功能,這樣利於我們後期的拓展。
方法的定義
- Java的方法類似於其它語言的函式,是一段用來完成特定功能的程式碼片段,一般情況下,定義一個方法包含以下語法:
- 方法包含一個方法頭和一個方法體。下面是一個方法的所有部分:
- 修飾符:這是可選的,告訴編譯器如何呼叫該方法,定義了該方法的訪問型別。
- 返回值型別:方法可能會有返回值。returnValueType是方法返回值的資料型別。有些方法執行所需的操作,但沒有返回值,在這種情況下,returnValueType是關鍵字void
- 方法名:是方法的實際名稱(小駝峰)
- 引數型別:引數像是一個佔位符。當方法被呼叫時,傳遞值給引數。這個值被稱為實參或變數。引數列表是指方法的引數型別、順序和引數的個數,引數是可選的,方法可以不包含任何引數。
- 形式引數:在方法被呼叫時用於接收外界輸入的資料
- 實參:呼叫方法時實際傳給方法的資料
- 方法體:方法體包含具體的語句,定該方法的功能。
修飾符 返回值型別 方法名(引數型別 引數名){ ... 方法體 ... return 返回值; }
方法呼叫
呼叫方法:物件名.方法名(實參列表)
Java支援兩種呼叫方法的方式,根據方法是否有返回值來選擇。
當方法有返回一個值得時候,方法呼叫通常被當做一個值,如:
int max = getMax(10,20);
如果方法沒有返回值,方法呼叫通常被當做一條語句
System.out.println("Hello,World!");
方法的過載
過載就是在一個類中,有相同的函式名稱,但形式引數不同的函式
方法過載的規則
- 方法名必須相同
- 引數列表必須不同(個數不同、型別不同或引數排列順序不同等等)。
- 方法的返回型別可以相同也可以不同。
- 僅僅返回型別不同不足以成為方法的過載
方法名稱相同時,編譯器會根據呼叫方法的引數個數、引數型別等去逐個匹配,以選擇對應的方法,如果匹配失敗,則編譯器報錯。
案例:求最大值
public class Demo {public static void main(String[] args) { double[] arr = {2, 8, 6}; //呼叫可變引數的方法 printMax(1,2); printMax(1.0,2.0); } public static void printMax(int a,int b){ int result = Math.max(a, b); System.out.println("The max value is " + result); } public static void printMax(double a,double b){ double result = Math.max(a, b); System.out.println("The max value is " + result); } }
輸出結果
可變引數
jdk1.5開始,Java支援給一個方法傳遞多個同類型的可變引數
在方法宣告中,在指定引數型別後加一個省略號(...)
一個方法中只能指定一個可變引數,它必須是方法的最後一個引數,任何普通的引數必須在它之前宣告
案例:
public class Demo { public static void main(String[] args) { double[] arr = {2, 8, 6}; //呼叫可變引數的方法 printMax(1,2,3,5,6); printMax(arr); } public static void printMax(double... numbers){ if (numbers.length == 0){ System.out.println("No argument passed"); } double result = numbers[0]; for (double number : numbers) { if (number > result) { result = number; } } System.out.println("The max value is " + result); } }
輸出結果
遞迴
A方法呼叫B方法,我們很容易理解
遞迴就是A方法呼叫A方法 自己呼叫自己
利用遞迴可以用簡單的程式來解決一些複雜的問題。它通常把一個大型複雜的問題,層層轉化為一個與原問題相似的規模較小的問題來求解,遞迴策略只需少量的程式就可描述出解題過程所需要的多次重複計算,大大減少了程式的程式碼量。遞迴的能力在於用有限的語句來定義物件的無限集合。
遞迴結構包括兩個部分:
遞迴頭:什麼時候不呼叫自身方法,如果沒有頭,將陷入死迴圈
遞迴體:什麼時候需要呼叫自身方法
這樣理解有點麻煩,我們來舉個例子:求5的階乘
public class Demo { public static void main(String[] args) { System.out.println(getFactorials(5)); } public static int getFactorials(int i) { if (i == 1) { return i; } else { return i * getFactorials(i - 1); } } }
其中當i = 1的時候呼叫的方法就是遞迴頭,到這個迴圈就可以結束了
i = 2,3,4,5這些是遞迴體,這些時候要方法要呼叫自己