标签:没有 归并 str 输出 一段 传引用 bsp 方法 ati
最近在读《算法导论》,在尝试自己实现归并排序时,发现了一个很奇怪的问题。
为了能够专注于问题,下面使用一段重新编写的能够重现问题的代码。可以尝试运行一下。
1 public class Main 2 { 3 public static void main(String[] args) 4 { 5 int[] tmp = {4, 5, 6}; 6 Test.print(tmp); 7 Test.test(tmp); 8 Test.print(tmp); 9 } 10 } 11 class Test { 12 public static void test(int[] src) { 13 int[] out = {1, 2, 3}; 14 print(out); 15 src = out; 16 print(src); 17 } 18 public static void print(int[] src) { 19 for(int i : src) { 20 System.out.print(i + "\t"); 21 } 22 System.out.println(); 23 } 24 }
之前有听说Java是传引用的,且在上述例子中,若将test中的 src = out 改为数组逐元素复制,则最后一行输出将会变为 4 5 6 ,因而一开始并没有想到这方面的问题。然而,拿着这段代码问一位学长时(在此特别感谢符学长),得到答复称Java为传值。于是当时就迷糊了,决定对此详细了解一番。
经过查阅相关资料,了解到Java在传参数时是复制指针,但不进行进一步复制。那么,在执行上述代码的第七行时,应当发生了这些:
在以上过程中,由于被改变的是tmp的引用副本(即src),故tmp所指向的对象并未发生任何改变。原先的src与out所指向的对象已经失去所有指向其自身的指针,即将在不久后被销毁。而在数组逐元素复制中,src虽然是一个副本,但针对其所指向的对象所作的修改只依赖于指针所指向的对象而非指针本身,故此修改能够反映到tmp中。
参考文章:java中的经典问题:传值与传引用
另外最近成功用VPS建了个独立的博客,点击这里进入。
标签:没有 归并 str 输出 一段 传引用 bsp 方法 ati
原文地址:http://www.cnblogs.com/gresstant/p/7608827.html