【问题标题】:Assigning one array to another inside a merge method [duplicate]在合并方法中将一个数组分配给另一个数组[重复]
【发布时间】:2021-04-23 23:50:00
【问题描述】:

我正在尝试合并到数组 nums1 和 nums2...

m = nums1 中填充元素的大小 n = nums2 的大小

数组在方法中通过引用传递...因此,如果方法内部发生任何更改,它将反映在外部...所以我在merge方法内部分配nums1 = result...它在内部显示合并方法,当我通过以下代码打印 nums1 数组时:

    System.out.println("Result: " + Arrays.toString(nums1));

..所以 nums1 数组现在将指向“结果”数组.. 但是当我尝试通过下面的代码在“main”方法中打印相同的内容时:

System.out.println("Merged Array: " + Arrays.toString(nums1));

然后它没有显示所需的结果。即 nums1 应该显示“结果数组值”作为“合并”方法的更改..

请有人解释一下为什么会这样?

我合并两个数组的整个代码如下:

public class MergeSortedArray {

    public static void main(String[] args) {

        int[] nums1 = {1, 2, 3, 0, 0, 0}, nums2 = {2, 5, 6};
        
        int m = 3, n = 3;
        
        System.out.println("Original Array: nums1: " + Arrays.toString(nums1));
        System.out.println("Original Array: nums2: " + Arrays.toString(nums2) + "\n");

        
        
        merge(nums1, m, nums2, n);
        
        
        
        System.out.println("Merged Array: " + Arrays.toString(nums1));
        
    }
    
    
    public static void merge(int[] nums1, int m, int[] nums2, int n) {
        
        int n1idx = 0, n2idx = 0;
        
        int[] result = new int[nums1.length];
        
        int ridx = 0;
        
        while(n1idx < m && n2idx < n) {
            
            if(nums1[n1idx] < nums2[n2idx]) {
                
                result[ridx++] = nums1[n1idx++];
                
            } else {
                
                result[ridx++] = nums2[n2idx++];
                
                
            }
        
        }
        
        // fill the remaining elements from nums1
        while(n1idx < m) {
            
            result[ridx++] = nums1[n1idx++];
            
        }
        
        // fill the remaining elements from nums2
        while(n2idx < n) {
            
            result[ridx++]= nums2[n2idx++];             
        
        }
            
        nums1 = result;
        
        System.out.println("Result: " + Arrays.toString(nums1));
        
    }

}

【问题讨论】:

    标签: java arrays merge array-merge


    【解决方案1】:

    当您将result 分配给nums1 时,它不会更改被调用程序中的引用。它仅具有局部意义。这是因为实际的引用是按值传递的,你不能通过简单的赋值来改变它。

    但是,您在 merge 方法中对 nums1 内容所做的任何更改都将反映在调用程序中,因为您也在更改引用所指的内容,而不是引用本身。

    Java 中的一切都是按值传递的。甚至是数组和对象。

    这是一个例子。 Identityhash 显示了一个表示引用的值。请注意,在方法中最后一次赋值之后,传递的引用没有改变。

    public static void main(String[] args) {
          int[] q = {4,5,6};
          System.out.println("q in main = " + System.identityHashCode(q));
          callMethod(q);
          System.out.println("q in main = " + System.identityHashCode(q)); // hasn't changed
    }
    
    public static void callMethod(int[] v) {
        System.out.println("v in method = " + System.identityHashCode(v));
        int[] otherArray = new int[]{1,2,3};
        v = otherArray;
        System.out.println("v in method after assignment = " + System.identityHashCode(v));
        
    }
    

    打印

    q in main = 925858445
    v in method = 925858445
    v in method after assignment = 798154996
    q in main = 925858445
    

    【讨论】:

    • 是的,我知道..但是你没有回答我的问题..因为数组是在方法内部通过引用传递的..所以当它到方法内部的另一个数组时,现在应该参考新数组..为什么方法内部的这些变化没有反映在“main”方法中..?我有一个“概念上的疑问”..请解释一下。
    • 对不起,我修改了答案。
    猜你喜欢
    • 2014-07-14
    • 2016-06-04
    • 2018-08-22
    • 1970-01-01
    • 1970-01-01
    • 2018-02-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多