Java方法

一、什么是方法

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

方法是解决一类问题的步骤的有序组合

方法包含于类或对象中

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

方法的命名规则见之前的笔记(驼峰原则)

public class Demo01 {
    //main方法 psvm
    public static void main(String[] args) {
        //实际参数:实际调用传递给它的参数
        int sum = add(1,2);
        System.out.println(sum);
    }
    //加法
   //形式参数:用来定义作用的
    public static int add(int a,int b){ //static变成类变量
        return a+b;
    }
}

二、方法的定义及调用

Java方法类似于其他语言的函数

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

  • 修饰符:可选的,告诉编译器如何调用该方法,定义了该方法的访问类型
  • 返回值类型:方法可能会有返回值(int,double…),没有返回值用void
  • 方法名:方法的实际名称。方法名和参数表共同构成方法签名
  • 参数类型:(形参,实参)方法可以不包含任何参数
  • 方法体:方法体包含具体语句,定义该方法功能

方法调用:

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

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

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

    int s = max(30,40);

  • 方法返回值时void时,方法调用一定是一条语句

    System.out.printIn('');

public class Demo02 {
    public static void main(String[] args) {
        int max = max(2,10);
        System.out.println(max);
    }
    //比大小
    public static int max(int a,int b){
        int result = 0;
        if (a==b){
            System.out.println("a==b");
            return 0; //终止方法
        }
        if(a>b){
            result = a;
        }else{
            result = b;
        }
        return result;
    }
}

三、方法重载

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

方法重载的规则:

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

四、命令行传参

当你希望运行一个程序时再给它传递消息。需要靠传递命令行参数给main()函数实现

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

        }
    }
}

在这里插入图片描述

五、可变参数

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

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

public class Demo04 {
    public static void main(String[] args) {
        Demo04 demo04 = new Demo04();
        demo04.test(1,3,4,5);
    }
    // 一个函数只能有一个可变参数
    public void test(int x,int... i){
        System.out.println(i[0]);//3
        System.out.println(i[2]);//5
    }
}

六、递归

递归就是A方法调用A方法

递归结构包含两个部分:

  1. 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环
  2. 递归体:什么时候需要调用自身方法
public class Demo06 {
    //5! 5*4*3*2*1
    public static void main(String[] args) {
        System.out.println(f(5));

    }
    public static int f(int n){
        if (n==1){
            return 1;
        }else{
            return n*f(n-1);
        }
    }
}

七、练习(计算器)

import java.util.Scanner;

public class work {
    //写一个计算器
    public static void main(String[] args) {
        while (true) {
            System.out.println("欢迎使用简易计算器!");
            int result = 0;
            Scanner s = new Scanner(System.in);
            System.out.println("请输入第一个参数:");
            int a = s.nextInt();
            System.out.println("请输入第二个参数:");
            int b = s.nextInt();
            System.out.println("请选择你要进行的操作:加、减、乘、除");
            String p = s.next();
            switch (p) {
                case "加":
                    result = add(a, b);
                    System.out.println(a + "+" + b + "=" + result);
                    break;
                case "减":
                    result = sub(a, b);
                    System.out.println(a + "-" + b + "=" + result);
                    break;
                case "乘":
                    result = mul(a, b);
                    System.out.println(a + "*" + b + "=" + result);
                    break;
                case "除":
                    result = div(a, b);
                    System.out.println(a + "/" + b + "=" + result);
                    break;
                default:
                    System.out.println("请输入正确的运算!");
                    break;
            }
            System.out.println("是否继续计算?是:Y,否:N");
            String cout = s.next();
            if (cout.equals("N")){
                s.close();
                System.out.println("感谢使用!");
                break;
            }
        }
    }

    public static int add(int i,int j){
        return i+j;
    }
    public static int sub(int i,int j){
        return i-j;
    }
    public static int mul(int i,int j){
        return i*j;
    }
    public static int div(int i,int j){
        return i/j;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值