【手把手带你学JavaSE】第四篇:Java中的方法_java为什么不需要声明函数(1)

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

1.3 方法的开辟

函数开辟内存空间叫做函数栈帧,每个函数调用的时候都会开辟栈帧,属于这个函数的内存

函数在内存空间是如何调用的:

在这里插入图片描述
举例:用函数的方法求n的阶乘之和

 //用函数的方法求n的阶乘之和
public static int Fac(int n) {
        int sum = 1;
        for (int i = 1; i <= n; i++) {
            sum = sum \* i;
        }
        return sum;
    }
    /\*\*
 \* 求n的阶乘之和
 \* @param
 \*/
    public static int facSum(int n){
        int ret = 0;
        for (int i = 1;i <= n; i++){
            ret = ret + Fac(i);
        }
        return ret;
    }
 
    public static void main(String[] args) {
 
        System.out.println(facSum(5));
    }
}

//1.Java无法通过传地址的方式交换两个值的变量,后续会讲怎么做
public class TestDemo {
    public static void swap(int a,int b){//交换两个变量的值
        int tmp = a;
        a = b;
        b = tmp;
    }
 
    public static void main(String[] args) {
        int a = 10;
        int b = 10;
        System.out.println("交换实参前:"+a+" " +b);
        swap(&a,b);//Java是做不到取地址的,如果想要写一个函数交换两个数的的值,只能把a和b的值放到堆上
        System.out.println("交换实参后:"+a+" " +b);
 
    }
}

二、方法的重载

有些时候我们需要用一个函数同时兼容多种参数的情况, 我们就可以使用到方法重载.

2.1 重载要解决的问题

在这里插入图片描述
那么是不是应该创建这样的代码呢?
由于参数类型不匹配, 所以不能直接使用现有的 add 方法.

在这里插入图片描述
这样的写法是对的(例如 Go 语言就是这么做的), 但是 Java 认为 addInt 这样的名字不友好, 不如直接就叫 add

2.2 重载的规则

方法名相同
方法的参数不同(参数个数或者参数类型)
方法的返回值类型不影响重载.

当两个方法的名字相同, 参数也相同, 但是返回值不同的时候, 不构成重载.

三、方法的使用

例题:用函数方式编写代码模拟三次登录场景

   public static void login(){
        int count = 3;
        Scanner scanner = new Scanner(System.in);
        while(count != 0){
            System.out.println("请输入你的密码");
            String password = scanner.nextLine();
            if(password.equals("123456")){//equals的返回值是true或者false
                System.out.println("登录成功了");
                break;
            }else{
                count--;
                System.out.println("你输错密码了,你还有"+count+"次机会");
 
            }
        }
 
    }
 
    public static void main(String[] args) {
        login();
 
    }

例题:函数求水仙花数

//求水仙花数 
public static void findNum(int n){
 
        for (int i = 1; i <=n; i++) {
            int count = 0;//数字的位数
            int tmp = i;
            while(tmp != 0){
                count++;
                tmp = tmp/10;
            }
            tmp = i;
            int sum = 0;
            while(tmp != 0){
                sum += Math.pow(tmp%10,count);
                tmp/=10;
            }
            if(sum == i){
                System.out.println(i);
            }
 
        }
 
    }
 
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        findNum(n);
 
    }

例题:求奇数位于偶数之前

//调整数组顺序使得奇数位于偶数之前,调整之后,不关心大小顺序
public class TestDemo {
 
 
    public static void main(String[] args) {
        int[]arr = {1,2,3,4,5,6,7,8,9};
        int left = 0;
        int right = arr.length-1;
        while(left < right){
            while(left < right && arr[left] % 2 != 0){
                left++;
            }
            while(left < right && arr[right] % 2== 0){
                right--;
            }
            int tmp = arr[left];
            arr[left] = arr[right];
            arr[right] = tmp;
        }
        for (int i = 0; i <arr.length ; i++) {
            System.out.print(arr[i]+" ");
 
        }
 
    }
 
 
}

例题: 函数求三个数的最大值

//1.用函数求三个数的最大值
public class TestDemo {
 
 
 
    public static int Max(int a,int b){
        return a > b? a : b;
 
    }
        public static int Max1(int a,int b,int c){
        return Max(Max(a,b),c);
        }
 
    public static void main(String[] args) {
        System.out.println(Max1(4, 6, 8));
 
    }
 
}

方法递归

一个方法在执行过程中调用自身, 就称为 “递归”.递归相当于数学上的 “数学归纳法”, 有一个起始条件, 然后有一个递推公式.
例如, 我们求 N!
起始条件: N = 1 的时候, N! 为 1. 这个起始条件相当于递归的结束条件.
递归公式: 求 N! , 直接不好求, 可以把问题转换成 N! => N * (N-1)!

代码示例:

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

715004085789)]
[外链图片转存中…(img-GKLEzkiT-1715004085789)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值