概念准备
值传递和引用传递 值传递:对所传递的参数进行一个副本拷贝,方法中所有操作只是对副本进行操作,方法结束后副本被丢弃(即实参不变),Java中只有值传递,即便传引用类型也是传递引用的副本 引用传递:传参时不拷贝副本,直接将参数本身传递到方法内部,方法内对参数所有操作都会直接反映到原参数上
形参和实参 形参:方法中声明的参数 实参:方法调用时实际传入的参数
示例代码
public class Demo3 {
public static void main(String[] args) {
int i = 1;
String str = "hello";
Integer num = 200;
int[] arr = {1, 2, 3, 4, 5};
MyTest myTest = new MyTest();
change(i, str, num, arr, myTest);
System.out.println("i = " + i);
System.out.println("str = " + str);
System.out.println("num = " + num);
System.out.println("arr = " + Arrays.toString(arr));
System.out.println("myTest.a = " + myTest.a);
}
public static void change(int i, String str, Integer num, int[] arr, MyTest myTest) {
i += 1;
str += "world";
num += 1;
arr[0] = 100;
myTest.a += 1;
}
}
运行结果
i = 1
str = hello
num = 200
arr = [100, 2, 3, 4, 5]
myTest.a = 11
Process finished with exit code 0
结果分析
首先明白实参给形参赋值时,传递的都是实参的副本。Java中传递参数,基本类型传递的是参数值,引用类型传递的是参数引用地址。让我们根据结果逐个分析: i: 传递的是值副本,change()方法内部操作不会影响到实参 str: 传递的是引用副本,那就奇怪了,既然传递的是引用,方法内部在原地址上进行修改,为什么原参数没有修改呢?因为Java中String类型和包装类型的不可变性,修改时实际上是在字符串常量池或堆内存中重新创建一个新对象,然后将新的引用地址赋值给变量,修改的也只是副本,原参数引用地址没有改变所以不受影响 num: 同上 arr: 修改过程中没有创建新对象,方法中所有操作都直接作用在原对象 myTest: 同上
|