原理
Java对象作为参数传递给一个方法时,实际上传递的是这个对象引用的拷贝,被拷贝的引用和拷贝的引用指向同一个内存地址,即同一个对象
所以如果在方法中改变参数引用(拷贝的引用)指向的内存地址,对方法外的引用是不会产生任何影响的
若想对方法外的引用也产生影响,其一、可以在方法中调用对象的方法,应为两个引用指向的内存地址是一样的,即同一个对象,例如List集合的add方法等。其二、可以把方法的返回值重新赋值给原来的引用
第一种情况
调用对象的方法
@Test
public void testList(){
List<String> strList1 = new ArrayList<>();
strList1.add("strList1 add string1");
strList1.add("strList1 add string2");
addElements1(strList1);
for(String str : strList1){
System.out.println(str);
}
}
public void addElements1(List<String> strList){
strList.add("strList add string1");
strList.add("strList add string2");
}
结果:
strList1 发生了改变
strList1 add string1
strList1 add string2
strList add string1
strList add string2
内存分析:
第二种情况
参数引用重新指向新的内存地址表现一
@Test
public void testList(){
List<String> strList1 = new ArrayList<>();
strList1.add("strList1 add string1");
strList1.add("strList1 add string2");
addElements2(strList1);
for(String str : strList1){
System.out.println(str);
}
}
public void addElements2(List<String> strList){
strList = new ArrayList<>();
strList.add("strList add string1");
strList.add("strList add string2");
}
结果:
strList1 没有发生了改变
strList1 add string1
strList1 add string2
内存分析:
第三种情况
参数引用重新指向新的内存地址表现二
@Test
public void testList(){
List<String> strList1 = new ArrayList<>();
strList1.add("strList1 add string1");
strList1.add("strList1 add string2");
addElements3(strList1);
for(String str : strList1){
System.out.println(str);
}
}
public void addElements3(List<String> strList){
List<String> strList2 = new ArrayList<>();
strList2.add("strList2 add string1");
strList2.add("strList2 add string2");
strList = strList2;
}
结果:
strList1 没有发生了改变
strList1 add string1
strList1 add string2
内存分析: