Day.5

java方法詳解

何爲方法

  • jav方法是語句的集合,它們在一塊兒執行一個功能java

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

  • 方法包含於類或對象中spa

  • 方法在程序中被建立,在其餘地方被引用命令行

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

方法的定義

  • java的方法相似於其餘語言的函數,是一段用完成特定功能的代碼片斷,通常狀況下,定義一個方法包括如下語法:修飾符 返回值類型 方法名 (參數類型 參數名){對象

    .....遞歸

    方法體編譯器

    .....string

    return 返回值;it

    }

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

      1. 修飾符:修飾符是可選的,告訴編譯器如何調用該方法。定義了該方法的訪問類型。

      2. 返回值類型:方法可能會返回值。returnValueType是方法返回值的數據類型。有些方法執行所須要的操做,但沒有返回值。在這種狀況下,returnValueType是關鍵字void。

      3. 方法名:是方法的實際名稱。方法名和參數表共同構成方法簽名。

      4. 參數類型:參數像是一個佔位符。當方法被調用時,參數值給參數。這個值被稱爲實參或變量。參數列表指方法的參數類型,順序和參數的個數。參數固然是可選的,方法能夠不包含任何參數。

        • 形式參數:在方法被調用時用於接受外界輸入的數據。

        • 實參:調用方法時實際傳給方法的數據

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

方法的調用

  • 調用方法:對象名.方法名(實參列表)

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

  • 當返回一個值的時候,方法調用一般被看成一個值。例如: int large = max(30,40);

  • 若是方法的返回值是void,方法調用必定是一條語句。例如: System.out.println("Hello,world")

方法的重載

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

  • 方法的重載的規則:

    1. 方法名稱必須相同

    2. 參數列表必須不一樣(個數不一樣,類型不一樣,參數順序不一樣等)

    3. 方法的返回類型能夠相同也能夠不一樣

    4. 僅僅返回類型不一樣不足以成爲方法的重載

  • 實際理論:方法名稱相同時,編譯器會根據調用方法的參數個數,參數類型等去逐個匹配,以選擇對應的方法,若是匹配失敗,則編譯器報錯。

命令行傳參

有時候你但願運行一個程序時候在傳遞給它消息。這要靠傳遞命令行參數給main()函數實現。

![image-20200721172349606](C:\Users\14036\AppData\Roaming\Typora\typora-user-images\image-20200721172349606.png

for(int i = 0;i<args.length;i++){
  System.out.println("args["+i+"]:"+args[i]);
}

image-20200721172512737

可變參數

  • JDK1.5開始,Java支持傳遞同類型的可變參數給方法。

  • 在方法聲明中,在指定參數類型後加一個省略號(...)。

  • 在一個方法聲明中只能指定一個可變參數,它必須是方法的最後一個參數。任何普通的參數必須在它以前聲明。

  public class Demo03 {
   public static void main(String[] args) {
       printMax(1,2,3,90,56.3,98.5); // 98.5
       printMax(new double[]{1,2,3,4,5});      // 5.0
  }
   public static void printMax(double...numbers){
       if(numbers.length == 0){
           System.out.println("沒有數字比較");
           return;
      }
       double result = numbers[0];
       for(int i = 1;i < numbers.length;i++){
           if(numbers[i]>result){
               result = numbers[i];
          }
      }
       System.out.println("最大數爲:"+result);
  }
}

遞歸

  • 遞歸就是:A方法調用A方法!就是本身調用本身

  • 利用遞歸能夠用簡單的程序來解決一些複雜的問題。它一般把一個大型複雜的問題層層轉化爲一個與原問題類似的規模較小的問題來求解,遞歸策略只需少許的程序就可描述出解題過程所須要的屢次重複計算,大大地減小了程序的代碼量。遞歸的能力在於1用有限的語句來定義對象的無限集合

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

    1. 遞歸頭:何時不調用自身的方法。若是沒有頭,將陷入死循環。

    2. 遞歸體:何時須要調用自身的方法。

public class Demo04 {
   public static int f(int i){
       if(i == 0)
      {
           return 1;
      }else
      {
           return i*f(i-1);
      }
  }
   public static void main(String[] args) {
       System.out.println(f(6));    //720
  }
}    

注意點:遞歸都用於較小數字計算。

相關文章
相關標籤/搜索