文章目录
1.什么是方法
2.方法的定义和使用
返回值类型
形参与实参
方法执行过程
3.方法的重载
4.递归
5.总结
1.什么是方法
方法就是组织好的,可重复使用的具有某种功能的特定代码块 (类似于函数)
在我们平时写代码时,如果遇到会经常使用的一些功能相同的代码时,我们就可以把这段代码写成一个方法,下次使用时直接调用方法即可.就不需要每次使用都要重新写一遍这些代码了.
2.方法的定义和使用
// 语法:
修饰符 返回值类型 方法名称([参数类型 形参 ...]){
方法体代码;
return 返回值;
}
修饰符:方法的修饰符有很多,例如访问限定修饰符,static,final等
返回值类型:限定返回值的类型
参数类型:用于限定形参的类型
形参:用于接收传入的变量
return:返回一个数值并结束方法
假如我在平时写代码中,要经常要对两个数相加求和,那么我就可以写一个方法来实现这个功能
例如:
public static int add(int x,int y){
return x+y;
}
定义方法的时候, 不会执行方法的代码. 只有调用的时候才会执行.
方法的调用示例:
public static void main(String[] args) {
int ret = add(1,2);
System.out.println(ret);
}
// 输出结果: 3
一个方法可以被重复调用多次.
使用方法的好处
避免了代码重复,提高开发效率
利于维护,需要改动时,只需要修改方法即可
注意: 函数不能嵌套定义,Java中也不存在方法的声明
返回值类型
对于方法的返回值类型,根据自己的需求设置即可.
示例:如果要返回两个数中最大的那个数.
此时我们要得到这个数,就可以将最大值进行返回
代码如下:
public static int getMax(int n,int m){
return n > m? n : m;
}
但是如果我们只是想输出两个数中的最大值,那么此时有两种选择:1.直接在方法体内部进行输出 2.返回最大值,在main方法中进行输出
代码如下:
public static int getMax1(int n,int m){
return n > m? n : m;
}
public static void getMax2(int n,int m){
int ret = n > m ? n : m;
System.out.println(ret);
}
public static void main(String[] args) {
int ret = getMax1(7,6);
System.out.println(ret);
getMax2(7,6);
}
形参与实参
以刚才的代码进行演示:
形参是定义方法时()中的变量,形参的作用只是接收实参传递过来的值的,形参的取名是任意的,对方法没有任何影响
看下图:
swap函数用于交换n和m的值.可以看到在方法体内部n和m是交换成功了,但是在main方法中调用swap方法去交换a和b的值,却没有任何影响.是为什么呢?
其实就是因为实参在给形参传递时,只是把值传过去了,形参可以是实参的一个副本而已,因此swap函数的本质只是对形参进行了交换,并不会影响实参. 但是引用类型可以进行交换,最典型的就是数组,把这两个数放到数组中,交换数组中这两个下标的值可以进行交换.后面会进行讲解,在这里就不赘述了.
方法执行过程
调用方法->传递参数->找到方法地址->执行被调方法的方法体->被调方法结束返回->回到主调方法继续往下执行
3.方法的重载
什么是方法的重载呢?
可以简单的理解为"一词多义" 就比如刚才的add方法.只是两个整数进行相加,那我如果再写一个add方法想要三个整数进行相加,或者两个浮点数进行相加.这种方法名不变,形参的个数 顺序不一样就构成了方法的重载
例如:
public static int add(int x,int y){
return x+y;
}
public static int add(int x,int y,int z){
return x+y+z;
}
public static double add(double x,double y){
return x+y;
}
这就是方法的重载
注意
方法的重载与返回值无关
参数列表不能相同(形参的个数 顺序 类型等)
方法名必须相同
4.递归
递归指的是在函数的定义中使用函数自身的方法。
接下来通过一个示例来认识以下递归
例题: 输入一个n,求n的阶乘
解法1:使用循环进行求解
public static int factorial(int n){
int ret = 1;
for (int i = 1; i <= n; i++) {
ret *= i;
}
return ret;
}
不过现在讲的是阶乘,接下来来看一下递归的求解方法.
public static int factorial(int n){
if (n == 1){
return 1;
}
return n*factorial(n-1);
}
运行截图:
以下是factorial(5)在运行时执行的流程:
在n 不等于 1时,执行 n * factorial(n-1).在n 等于 1 时,返回1.然后从最后一层开始往前返回,并返回最终结果.
递归在最开始接触的时候,难度还是不小的,建议去梳理一下递归的执行流程,有助于更好的理解递归
5.总结
方法在实际开发中使用的是非常多的,要重点掌握重载和递归.