public class Test02 {
public static void main(String[] args) {
StringBuffer a = new StringBuffer("A");
StringBuffer b = new StringBuffer("B");
operator(a, b);
System.out.println(a + "," + b);
}
public static void operator(StringBuffer x, StringBuffer y) {
x.append(y); y = x;
}
}
大家觉得这个a和b的值会是多少呢?
结果是AB,B
是不是和你的答案一样呢?
其实这个就是所谓的按值传递。
Java中任意类型都其实是按值传递,没有所谓的按引用传递。
至少,现在是。
因为,如果是按引用传递的话,b的值就绝对会被改变,因为它把原来b的指向改变了,然而,事实告诉我们,并不是这样。
方法中的y只是b的一个副本,他一开始有着和b一样的指向,也就是跟着这个指向能找到和b一样的值,所以我们就能看到b和y相等。
但是,无论你怎么改变y的指向,比如给他新的地址值,那y的指向就一定会变化,所以他的值会变。不过,这丝毫不会影响原来b的指向,因为y不是b!
那么,你是否疑问,那为什么a的值被改变了呢?
嘿嘿,那是因为a的指向的地址值被赋给x,这毫无争议是吧?
接着,调用了x的append方法,然后系统跟着x的指向,找到了x所指向的那块内存,这块内存同时也是a所指向的内存,也就意味着,系统直接找到了a的老巢!!!
然后对这块内存进行了修改,所以这块内存的值被改变了。
而a的地址依旧指向这块内存,所以a的值变成了AB。