方法

方法

1. 何为方法

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

  1. 方法是解决一类问题的步骤的有序组合
  2. 方法包含于类或对象中
  3. 方法在程序中被创建,在其他地方被引用

设计方法的原则:一个方法只完成一个功能

package com.ylmxy.method;

public class Demo01 {
    //main方法
    public static void main(String[] args) {
/*        int sum = add(1, 2);
        System.out.println(sum);*/
        test();
    }

    //加法
    public static int add(int a, int b) {
        return a + b;
    }

    public static void test() {
        for (int i = 1; i <= 5; i++) {
            for (int i1 = 5; i1 >= i; i1--) {
                System.out.print(" ");
            }
            for (int i2 = 1; i2 <= i; i2++) {
                System.out.print("*");
            }
            for (int i3 = 1; i3 < i; i3++) {
                System.out.print("*");
            }
            System.out.println();
        }
    }
}

2. 方法的定义

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

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

public class Demo02 {
    public static void main(String[] args) {
        int max = max(10, 20);
        System.out.println(max);
    }

    //比大小
    public static int max(int num1, int num2){

        int result = 0;

        if (num1==num2){
            System.out.println("num1==num2");
            return 0;//终止方法
        }
        if (num1>num2){
            result = num1;
        }else {
            result = num2;
        }
        return result;
    }
}

调用方法:对象名.方法名(实参列表)

3. 方法的重载

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

方法的重载的规则:

  1. 方法名称必须相同
  2. 参数列表必须不同(个数不同、或类型不同参数排列顺序不同等)
  3. 方法的返回类型可以相同也可以不相同
  4. 仅仅返回类型不同不足以成为方法的重载

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

4. 可变参数

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

package com.ylmxy.method;

public class Demo04 {
    public static void main(String[] args) {
        printMax(34,3,3,2,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);
    }
}

5. 递归

A方法调用A方法

递归结构包括两个部分:

  1. 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环
  2. 递归体:什么时候需要调用自身方法
package com.ylmxy.method;

public class Demo06 {
    public static void main(String[] args) {
        System.out.println(f(5));
    }
    //1! 1
    //2! 2*1
    //5! 5*4*3*2*1
    public static int f(int n){
        if (n == 1){
            return 1;
        }else {
            return n*f(n-1);
        }
    }
}
posted @ 2022-08-13 16:45  YlMXY  阅读(74)  评论(0)    收藏  举报