基本数据类型参数(传递的是值)
public static void main(String[] args) {
int s1 = 1;
int s2 = 2;
swapNum(s1,s2);
System.out.print(s1+"\t"+s2);
}
public static void swapNum(int m, int n) {
int t = m;
m = n;
n = t;
System.out.println("置换:"+m+"\t"+n);
}
结果:
置换:2 1
1 2
因为JVM都在main方法和swapNum方法里分别都开辟了内存空间用来存储变量,彼此隔离
引用类型参数(传递的是内存地址值)
当参数是引用类型时,比如:定义数组时,在堆内存中存储了数组的数据,返回这组数据的地址给了数组名,然后在调用方法时,传递的也是这个地址。在方法中,同样也是根据这个地址找到数组的信息,然后改变了这个数据的,所以之后main方法输出时,输出的是改变了之后的数组。即:此时跟栈和堆有关系,栈可以弹栈,堆内存不能弹出。
可变参数
- 什么是可变参数
1、在定义方法时,可以声明数量不确定的参数,这样的参数叫可变的参数
2、一个方法最多声明一个可变参数,并且该参数必须位于参数列表的末尾
3、可变参数的本质是一个数组,调用是可以分开传入多个值,也可以直接传入一个数组
方法重载和重写
- 什么是方法重载
在同一个类里,定义多个名称相同、参数列表不同的方法,叫做方法重载 - 什么是方法重写
重写发生在父类子类中,若子类方法想要和父类方法构成重写关系,则它的方法名、参数列表必须与父类方法相同。另外,返回值要小于等于父类方法,抛出的异常要小于等于父类方法,访问修饰符则要大于等于父类方法。还有,若父类方法的访问修饰符为private,则子类不能对其重写。
方法递归
- 什么是方法递归
1、一个方法调用它自身,被称为方法递归
2、递归他也是一个隐式的循环,他会重复执行某段代码,却无需循环控制
示例
//阶乘 n = n * (n-1) 结果:n=5 阶乘=120
public static long factorial(int n) {
if (n ==1) {
return 1;
}
return n * factorial(n-1);
}
//菲波那切数列
// 1,1,2,3,5,8,13 结果:n=6 菲波那切数列=8
// f(1) = 1, f(2) = 1, f(x) = f(x-1) + f(x-2)
public static long fibonacci(int n) {
if (n == 1 || n == 2) {
return 1;
}
return fibonacci(n - 1) + fibonacci(n - 2);
}