public class Test{
public static void main(String[] args){
int[] arr = {10, 20};
swap(arr);
System.out.println("a = " + arr[0] " b = " + arr[1]);
}
public static void swap(int[] arr){
int tmp = arr[0];
arr[0] = arr[1];
arr[1] = tmp;
}
}
// 运行结果为 a = 20 b = 10
二、方法的重载
1. 重载要解决的问题
什么是重载呢?大家可能都会有这个疑问,接下来我们直接用一个代码,揭开重载的面纱
public class Test{
public static void main(String[] args){
//当我们求两个整数和时
int a1 = 10;
int b1 = 20;
int ret1 = add(a1, b1);
System.out.println("ret1 = " + ret1);
//当我们求两个浮点数和时
double a2 = 1.5;
double b2 = 2.4;
double ret2 = a2 + b2;
System.ouy.println(“ret2 =” + ret2);
}
public static int addInt(int a, int b){
return a + b;
}
public static double addDouble(double a, double b){
return a + b;
}
}
上面我们分别对整数和浮点数求和都写了一个方法,这个做法也是对的。但是 Java 认为 addInt 这样的名字不友好,不如直接就叫 add。啥意思呢,在 java基础语法项目 Java 中上述代码可以写出这样
public class Test{
public static void main(String[] args){
//当我们求两个整数和时
int a1 = 10;
int b1 = 20;
int ret1 = add(a1, b1);
System.out.println("ret1 = " + ret1);
//当我们求两个浮点数和时
double a2 = 1.5;
double b2 = 2.4;
double ret2 = a2 + b2;
System.ouy.println(“ret2 =” + ret2);
}
public static int add(int a, int b){
return a + b;
}
public static double add(double a, double b){
return a + b;
}
}
细心的可以发现我们把方法名都叫作了 add,这个就叫做重载
2. 什么是重载
- 含义
同一个方法名字相同,提供不同版本的实现,称为重载
- 满足要求
- 方法名相同
- 参数列表不同(参数的个数或者参数的类型不同)
- 返回值不作要求
以上条件都满足时,才是重载。后面我们还会讲到重写,这是面试时时常会被问到的问题
- 注意事项
重载不是必须在一个类当中(继承)
三、方法递归
1. 什么是递归
- 概念
一个方法在执行过程中调用自身,就称为“递归”
- 实行条件
- 存在限制条件,当满足这个限制条件的时候,递归便不再继续
- 每次递归调用之后越来越接近这个限制条件
递归其实就是调用自己嘛,如果不存在限制条件只是调用自己的话,就可能有错误,如
public class Test{

public static void main(String[] args){
func();
}
public static void func(){
func();
}
}
上述代码就会栈溢出(StackOverflowError),因为方法调用时都会在栈上开辟内存,无休止的调用就会导致无休止的开辟,使栈溢出
2. 递归执行过程分析
既然知道什么是递归后,我们先来看一个求 n 的阶乘的例子
public class Test{
public static void main(String[] args){
int num = 4;
int ret = factor(num);
System.out.println(ret);
}
public static int factor(int n){
if(n == 1 || n == 0)
return 1;
else
return n * factor(n-1);
}
}
// 结果为24
而接下来我用两种方法为大家分析一下递归的执行过程
- 分析方法一
讯享网
讯享网
- 分析方法二
3. 递归练习
接下来我们做几个练习,让方法递归的理解更加深刻一些吧!
- 按顺序打印一个数字的每一位
public static void print(int num){
if(num < 10)
System.out.print(num);
else{
print(num / 10);
System.out.print(num % 10);
}
}
- 求 1 + 2 + … + n 的和
public static int sum(int num){
if(num == 1)
return 1;
else
return num + sum(num - 1);
}
- 写一个递归方法,输入一个非负整数,返回组成它的数字之和
public static int sum(int num){
if(num < 10)
return num;
else
return num % 10 + sum(num / 10);
}
- 求斐波那契数列数列的第 N 项
public static int fic(int num){
if(num == 1 || num == 2)
return 1;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。


既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
如何快速更新自己的技术积累?
- 在现有的项目里,深挖技术,比如用到netty可以把相关底层代码和要点都看起来。
- 如果不知道目前的努力方向,就看自己的领导或公司里技术强的人在学什么。
- 知道努力方向后不知道该怎么学,就到处去找相关资料然后练习。
- 学习以后不知道有没有学成,则可以通过面试去检验。
我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!
以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目


《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
目前的努力方向,就看自己的领导或公司里技术强的人在学什么。
- 知道努力方向后不知道该怎么学,就到处去找相关资料然后练习。
- 学习以后不知道有没有学成,则可以通过面试去检验。
我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!
以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目
[外链图片转存中…(img-uc719iNg-41)]
[外链图片转存中…(img-cpqVYMsQ-41)]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/4573.html