未验证 提交 48955149 编写于 作者: 木木匠 提交者: GitHub

Update 第一周(2018-8-7).md

完善下StringBuffer类型传递 中method1()方法和change1()输出结果原因分析。
上级 f4038e40
......@@ -133,6 +133,17 @@ public static void change(int[] array) {
因为在`change1`方法内部我们是新建了一个StringBuffer对象,所以`str`指向了另外一个地址,相应的操作也同样是指向另外的地址的。
把上面的代码解析成字节码分析就比较直观了,change1()方法解析成字节码如下:
```
0 new #2 <java/lang/StringBuffer>
3 dup
4 ldc #8 <abc>
6 invokespecial #4 <java/lang/StringBuffer.<init>>
9 astore_0
10 return
```
我们知道,每个方法都是一个栈帧,每个栈帧都维护有一个局部变量表,分析第6步,发现调用了stringBuffer方法的初始化,也就是执行了```new StringBuffer("abc");```方法,接下来第9步是把栈顶的对象(也就是调用chang1方法传来的StringBuffer引用)加载进局部变量表弟一个slot中,接着方法就结束了,所以这个引用直接存到了change1的局部变量表中,而method1中输出的str还是自己的局部变量表中的引用,所以,change方法并不影响输出结果。
那么,如果将`change1`方法改成如下图所示,想必大家应该知道输出什么了,如果你还不知道,那可能就是我讲的有问题了,我反思(开个玩笑,上面程序中已经给出答案):
```
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册