Java方法详解

何为方法

Java方法是语句的集合,他们在一起执行一个功能

1.方法是解决一切问题的步骤的有序组合

2.方法包含于类或对象中

3.方法在程序中被创建,在其他地方被引用

设计方法的原则

方法的本意是功能块,就是实现某个功能的语句块集合,我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成1个功能,这样利于我们后期的扩展

方法的定义及调用

方法包含一个方法头和一个方法体

  • 修饰符:修饰符,是可选的,告诉编译器如何调用该方法,定义了该方法的的访问类型。

  • 返回值类型:方法可能会返回值,returnValueType 是方法返回值的数据类型,有些方法执行所需的操作,但没有返回值,在这种情况下,returnValueType 的关键字是void

  • 方法名:是方法的实际名,方法名和参数表共同构成方法签名

  • 参数类型:参数像是一个占位符,当方法被调用时,传递值给参数,这个值被称为实参或变量,参数列表是指方法的参数类型,顺序,和参数的个数,参数是可选的,方法可以包含任何参数

    • 形式参数:在方法被调用时用于接收外界输入的数据

    • 实参:调用方法时实际传给方法的数据

  • 方法体:方法体包含具体的语句,定义该方法的功能

    修饰符 返回值类型 方法名(参数类型 参数名){
      ...
       方法体
      ...
       return 返回值;
    }

     

方法重载

  • 重载就是在一个类中,有相同的函数名称,但形参不同的函数

  • 方法的重载的规则

    • 方法名称必须相同

    • 参数列表必须不同(个数不同,或类型不同,参数排列顺序不同等)

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

    • 仅仅返回类型不同不足成为方法的重载

  • 实现理论

    • 方法名称相同时,编译器会根据调用方法的参数个数,参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错

命令行参数

 

可变参数

  • 在方法声明中,在指定参数类型后加一个省略号(...)

  • 一个方法中只能指定一个可变参数,他必须是方法的最后一个参数,任何普通的参数必须在他之前声明

    public class Demo03 {
       public static void main(String[] args) {
           printMax(15,5,78,54,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];//相当于数组,把输入的数字存放在numbers[i]里面
           //排序
           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方法!就是自己调用自己

  • 递归结构包括两个部分:

    • 递归头:什么时候不调用自身方法,如果没有头,将陷入死循环

    • 递归体:什么时候需要调用自身方法

      public class Demo04 {
        public static void main(String[] args) {
            System.out.println(f(1));
        }//递归思想
        public static int f(int n){
            if (n==1){
                return 1;
            }else {
                return n*f(n-1);
            }
        }
      }
    •