先上代码
public class Test {
public static void main(String[] args) {
int i=1;
System.out.println("i is "+i);
change1(i);
System.out.println("i is "+i);
MuObject muObject = new MuObject(4);
System.out.println("muObject is "+ muObject);
change2(muObject);
System.out.println("muOjbect is "+ muObject);
}
public static void change1(int i){
i=4;
System.out.println("change i to "+i);
}
//说明 java的参数都是值传递, 这里传递的只是复制对象的引用地址给局部变量muObject上
public static void change2(MuObject muObject){
muObject = new MuObject(2);
System.out.println("change muObject to "+muObject);
}
static class MuObject{
public int i;
public MuObject(int i){
this.i=i;
}
@Override
public String toString() {
return "MuObject [i=" + i + "]";
}
}
}
当调用方法时,方法会自动生成一个局部变量,并且外面的对象的引用地址被复制到这里,所以方法中的赠Object也是指向堆里的对象(4)
而这里给方法中的muObject赋值对象(2),相当于下图
所以,对于方法中的muObject它的引用地址已经改变了,但外面的对象它的引用地址还是对象(4),由此可知方法的传参还是值引用,只是引用类型的值是引用地址地址而已!