Java方法

何为方法

  • Java方法是语句的集合,它们在一起执行一个功能,方法包含于类或对象中,方法在程序中被创建,在其他地方被引用
  • 设计方法的原则:保持方法的原子性-一个方法只完成1个功能,这样利于后期的拓展
public class Demo01 {
    public static void main(String[] args) {
        int sum = add(1,2);
        System.out.println(sum);
        }

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

方法的定义

  • Java的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个方法包括以下语法:
  • 方法包括一个方法头和方法体
  1. 修饰符:修饰符,这是可选的,告诉编译器如何调用方法。定义了该方法的访问类型
  2. 返回值类型:方法可能会返回值。returnValueType是方法返回值的数据类型。有些方法执行所需的操作,但没有返回值。在这种情况下,returnValueType是关键字void
  3. 方法名:是方法的实际名称。方法名和参数表共同构成方法签名
  4. 参数类型:参数像是一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数
  5. 方法体:方法体包含具体的语句,定义该方法的功能
public class Demo02 {
    public static void main(String[] args) {
        int max = max(20,20);
        System.out.println(max);
    }

    //比较两个数的大小
    public static int max(int x,int y){
        int result = 0;
        if (x==y){
            System.out.println("两数相等!");
            return 0;    //终止方法
        }else if (x>y){
            result = x;
        }else {
            result = y;
        }
        return result;
    }
}

方法的重载

  • 重载就是在一个类中,有相同的函数名称,但形参不同的函数
  • 方法的重载的规则:
    1. 方法的名称必须相同
    2. 参数列表必须不同(个数不同、类型不同、参数排列顺序不同等)
    3. 方法的返回类型可以相同也可以不相同
    4. 仅仅返回类型不同不足以成为方法的重载
  • 实现理论:
  • 方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错
public class Demo03 {
    public static void main(String[] args) {
        double max = max(30.1,20.8);
        System.out.println(max);
    }
    //比较两个整数的大小
    public static int max(int x,int y){
        int result = 0;
        if (x==y){
            System.out.println("两数相等!");
            return 0;    //终止方法
        }else if (x>y){
            result = x;
        }else {
            result = y;
        }
        return result;
    }
    //比较两个浮点数的大小
    public static double max(double x,double y){
        double result = 0;
        if (x==y){
            System.out.println("两数相等!");
            return 0;    //终止方法
        }else if (x>y){
            result = x;
        }else {
            result = y;
        }
        return result;
    }
}

命令行传参

  • 运行一个程序的时候再给它传递消息,这要靠命令行传参给main()函数实现
public class Demo04 {
    public static void main(String[] args) {
        for (int i = 0; i < args.length; i++) {
            System.out.println("args["+i+"]:"+args[i]);
        }
    }
}

可变参数

  • JDK1.5开始,Java支持传递同类型的可变参数
  • 在方法声明中,在指定的那个参数类型后加一个省略号(...)
  • 在一个方法中只能指定一个可变参数,它必须是方法的最后一个参数,任何普通的参数必须在它之前声明
public class Demo05 {
    public static void main(String[] args) {
        printMax(10,20,30,52.6);  //传递值
        printMax(new double[]{15,26.3,78}); //传递数组
    }
    //传递可变参数number--等价于一个可变数组
    public static void printMax(double... numbers){
        if (numbers.length==0){
            System.out.println("No argument passed");
            return;
        }
        //简单选择排序,result保存最大值
        double result = numbers[0];
        for (int i = 0; i < numbers.length; i++) {
            if (result<numbers[i]){
                result = numbers[i];
            }
        }
        System.out.println("The max value is:"+result);
    }
}

递归

  • 递归就是:A方法调用A方法!自己调用自己
  • 利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可以描述出解题过程所需要的多次重估计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合
  • 递归结构包括两个部分:
  • 递归头:什么时候不调用自身方法,如果没有头将陷入死循环
  • 递归体:什么时候需要调用自身方法
  • 递归需要耗费大量的空间,在数据很大时,避免使用
public class DiGuiDemo {
    public static void main(String[] args) {
        System.out.println(f(5));
    }
    public static int f(int n){
        //递归头
        if(n==1){
            return 1;
        }
        //递归体
        return n*f(n-1);
    }
}

作业

  • 写一个计算器,要求实现加减乘除的功能,并且能够循环接收新的数据,通过用户交互实现
public class WorkDemo {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入第一个数:");
        int num1 = 0;
        if(scanner.hasNextInt()){
            num1 = scanner.nextInt();
        }
        System.out.println("请输入运算符:");
        String s = " ";
        if (scanner.hasNext()){
            s = scanner.next();
        }
        System.out.println("请输入第二个数:");
        int num2 = 0;
        if(scanner.hasNextInt()){
            num2 = scanner.nextInt();
        }
        switch (s){
            case "+" :{
                System.out.println(num1+s+num2+"="+add(num1,num2));
                break;
            }
            case "-" :{
                System.out.println(num1+s+num2+"="+sub(num1,num2));
                break;
            }
            case "*" :{
                System.out.println(num1+s+num2+"="+mul(num1,num2));
                break;
            }
            case "/" :{
                System.out.println(num1+s+num2+"="+div(num1,num2));
                break;
            }
            default:
                System.out.println("运算符不合法");
        }

        scanner.close();
    }
    public static int add(int a,int b){
        return a+b;
    }
    public static int sub(int a,int b){
        return a-b;
    }
    public static int mul(int a,int b){
        return a*b;
    }
    public static int div(int a,int b){
        return a/b;
    }
}
posted @ 2024-03-03 11:02  qing集  阅读(5)  评论(0编辑  收藏  举报