最近项目中出现了一个因为传参导致的一个Bug,为了防止以后再次出现这种问题。写了一个测试类。
public class Transfer {
public static void main(String[] args) {
int i = 1 ;
autoAdd(i);
System.out.println("最终的i值" + i); // 通过测试可知此时的i值并没有传递 ----因为变量存在与栈中。
String a = "a";
appendStr(a);
System.out.println("最终的字符串" + a);
a.contains("a");
Student stu = new Student();
stu.setName("张三");
System.out.println("开始时" + stu.toString());
changeStu(stu);
System.out.println("最终" + stu.toString()); // 说明修改的是堆中的信息
}
/**
* 自加1
* @param i
*/
public static void autoAdd(int i){
i++;
System.out.println("方法中的i值" + i);
}
/**
* 对字符串进行处理
* @param a
* @return
*/
public static String appendStr(String a){
String str = a + "b";
System.out.println("方法中的字符串" + str);
return str;
}
/**
* 改变方法中的学生信息
* @param stu
* @return
*/
public static Student changeStu(Student stu){
stu.setName("lisi");
System.out.println("方法中" + stu.toString());
return stu;
}
}
主要是考虑程序的执行流程,方法和方法中的常量引用都是存放在栈中的,首先加载的是main方法,然后将常量的引用1加入栈中。如果此时调用一个新的方法,就会将新的方法压入栈中,随后将方法中的常量2引用压入栈中(常量引用1和常量引用2并不相同,引用的指向也不相同),所以不会传递。 而对于堆中的数据来说,改变的是相同的一块空间,所以是地址传递。