第四课-Java方法

java方法

什么是方法

  • java方法是语句的集合,集合在一起执行一个功能

    • 方法是结局一类问题的步骤的有序组合
    • 方法包含于类或者对象中
    • 方法在程序中被创建,在其他地方被引用
  • 设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合.注意保证方法的原子性,即一个方法只完成一个功能,利于后期拓展

    package scanner;
    
    public class Demo02 {
        public static void main(String[] args) {
            int sum = add(1, 2);
            System.out.println(sum);
        }
    
        //方法名前面的int为返回值的类型
        public static int add(int a, int b) {
            return a + b;
        }
    }
    

方法的定义和调用

  • java的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段

  • 方法包含一个方法头和一个方法体,下面是一个方法的所有部分

    • 修饰符:可选,告诉编译器如何调用该方法,定义了该方法的访问类型
    • 返回值类型:方法可能会返回值.returnValueType是方法返回值的数据类型.有些方法执行所需的操作,但没有返回值.在这种情况下,returnValueType是关键字void
    • 方法名:是方法的实际名称.方法名和参数表共同构成方法签名
    • 参数类型:参数像是一个占位符.当方法被调用时,传递值给参数.这个值被称为实参或变量.参数列表是指方法的参数类型,顺序和参数的个数.参数是可选的,方法可以不包含任何参数.
      • 形式参数:在方法被调用时用于接受外界输入数据
      • 实参:调用方法是实际传给方法的数据
  • 方法体:方法体包含具体的语句,定义该方法的功能

    修饰符 返回值类型 方法名(参数类型 参数名){
        ...
        方法体
        ...
        return 返回值;
    }
    
  • 方法调用:对象名.方法名(实参列表)

  • java支持两种调用方法的方式,根据方法是否返回值来进行选择

    • 当方法返回一个值,方法调用通常被当作一个值

      int larger = max(30,40);
      
    • 如果方法返回值是void,方法调用一定是一条语句

      System.out.println("hello")
      
package scanner;

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

    public static int max(int a, int b) {
        int result = 0;

        if (a == b) {
            System.out.println("两数相等");
            return 0;  //return可以作为停止条件
        } else if (a > b) {
            result = a;
        } else {
            result = b;
        }
        return result;
    }
}

方法的重载

  • 重载就是在一个类中,有相同的函数(方法)名称,但形参不同的参数,即我们可以给函数相同的函数名称,只用调整形参的类型等参数,jvm会自动地帮我们调用正确的函数
  • 重载的规则:
    • 方法名称必须相同
    • 参数列表必须不同(个数不同或类型不同或参数的排列顺序不相同等)
    • 方法的返回类型可以相同也可以不相同.
    • 仅仅返回类型不同不足以成为方法的重载
  • 实现方法:方法名称相同时,编译器会根据调用方法的参数个数,参数类型去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错
package scanner;

public class Demo02 {
    public static void main(String[] args) {
        double max = max(10.0, 20.0);
        System.out.println(max);
    }

    public static int max(int a, int b) {
        int result = 0;

        if (a == b) {
            System.out.println("两数相等");
            return 0;  //return可以作为停止条件
        } else if (a > b) {
            result = a;
        } else {
            result = b;
        }
        return result;
    }

    public static double max(double a, double b) {
        double result = 0;

        if (a == b) {
            System.out.println("两数相等");
            return 0;  //return可以作为停止条件
        } else if (a > b) {
            result = a;
        } else {
            result = b;
        }
        return result;
    }
}

命令行传参

  • 有时候我们希望运行一个程序的时候再传递给它参数,这要靠传递命令行参数给main()方法实现
package scanner;

public class Demo02 {
    public static void main(String[] args) {
        // args.length 数组长度
        for (int i = 0; i < args.length; i++) {
            System.out.println("args[" + i + "]:" + args[i]);
        }
    }
}

可变参数

  • java支持传递同类型的可变参数给一个方法
  • 在方法声明中,在指定的参数类型后面加一个省略号
  • 一个方法中只能指定一个可变,同时必须是方法的最后一个参数,任何普通参数必须在它之前声明
package scanner;

public class Demo02 {
    public static void main(String[] args) {
        Demo02 demo02 = new Demo02();
        demo02.test(1, 2);
    }

    public void test(int... i) {
        System.out.println(i[0]);
        System.out.println(i[1]);
    }
}
package scanner;

public class Demo02 {
    public static void main(String[] args) {
        // 调用可变参数的方法
        printMax(34, 56.5, 62);
        printMax(new double[]{12, 56.2});
    }

    public static void printMax(double... numbers) {
        if (numbers.length == 0) {
            System.out.println("No argment passed");
            return;
        }

        double result = numbers[0];

        // 排序
        for (int i = 0; i < numbers.length; i++) {
            if (numbers[i] > result) {
                result = numbers[i];
            }
        }
        System.out.println("The max value is:" + result);
    }
}

递归

  • 递归:就是A方法调用A方法本身,自己调用自己
  • 利用递归可以实现使用一些简单的程序来解决复杂的问题 ,通常把一个大型的复杂的问题转变为一个与原问题相似嘚规模较小的问题来进行求解.通常只需要少量的代码就可以描述出解题过程所需的多次重复计算,大大减少程序的代码量,递归的能力在于用有限的语句来定义对象的无限集合.
  • 递归结构主要包括两个部分
    • 递归头(边界条件):什么时候不调用自身方法,即什么时候停止,如果没有头,将陷入死循环
    • 递归体:什么时候需要调用自身方法
  • 注意:递归对资源开销较大,一般用于小型问题当中
package scanner;

public class Demo02 {
    public static void main(String[] args) {
        System.out.println(f(4));
    }

    // 阶乘运算
    public static int f(int n) {
        if (n == 1) {
            return 1;
        } else {
            return n * f(n - 1);
        }
    }
}
posted @ 2021-04-17 23:50  vwxyz  阅读(120)  评论(0编辑  收藏  举报