数组克隆/复制

数组的复制/克隆

1.浅克隆

将原来数组的地址赋值给新数组,两个数组名指向了同一个数组,修改其中一个中的元素,那么他们查询到的元素都是修改过的元素

java 复制代码
public class Test01{
    public static void main(String [] args){
        
        	int [] arr = {10,20,30,40};
            int [] newArr =new int[arr.length]; //创建一个新的数组,长度和原来数组一样
            newArr = arr ;//将原来数组的地址赋值给新数组

            arr[1] = 100;  // 10  100  30  40 arr数组

            for(int i = 0;i<newArr.length;i++){
                System.out.println(newArr[i]+" "); //10  100  30  40 新数组
            }
    }
}

输出:

注意:任务是将arr的内容复制到newArr中,但是上面代码是数组地址的引用分配,这并不是真正的复制

2.深克隆

深克隆,为了解决浅克隆的问题,引用了for循环来将arr的元素,复制到newArr中。

java 复制代码
public class Test01{
    public static void main(String [] args){


        int [] arr = {10,20,30,40};
        int [] newArr =new int[arr.length]; //创建一个新的数组,长度和原来数组一样

        for(int i= 0;i<newArr.length;i++){ //因为长度一样,所以遍历两个数组都可以
            newArr[i] = arr[i]; //将arr的每一个元素赋值给newArr对应的每一个元素
        }

        //修改arr
        arr[1] = 100;  // 10  100  30  40 arr数组
        //打印arr
        for (int j : arr) {
            System.out.print(j + " "); //10  100  30  40 arr数组
        }
        System.out.println();
        //打印newArr
        for (int j : newArr) {
            System.out.print(j + " "); //10  20  30  40 newArr
        }
    }
}

输出:

结果表示,两个名字并不指向同一个数组地址

3.使用System.ArrayCopy()方法

java的system有一个ArrayCopy的方法可以将一个数组的元素复制到另外一个数组中

方法的原型:

java 复制代码
public static void arraycopy(
    Object src_array ,int src_Pos,Object dest_array,int dest_Pos,int length)

理解:

  • Object src_array:要用来复制元素的原数组
  • int arc_Pos: 开始复制索引位置
  • Object dest_array:目标数组
  • int dest_Pos: 要复制的元素在目标数组中的起始索引
  • int length: 要复制的数组长度

案例

java 复制代码
public class Test01{
    public static void main(String [] args){


        int [] arr = {10,20,30,40};
        int [] newArr =new int[arr.length]; //创建一个新的数组,长度和原来数组一样

        System.arraycopy(arr,0,newArr,0,arr.length);

        //修改arr
        arr[1] = 100;  // 10  100  30  40 arr数组

        //打印arr
        for (int j : arr) {
            System.out.print(j + " "); //10  100  30  40 arr数组
        }

        System.out.println(); 
        //打印newArr
        for (int j : newArr) {
            System.out.print(j + " "); //10  20  30  40 newArr
        }
    }
}

输出:

结果表示System.ArrayCopy()方法是深度克隆

4.使用Arrays.copyOf()方法

copyOf()方法属于Arrays类,是java.util下的一部分,内部采用了arraycopy()。

方法原型:

java 复制代码
public static int[] copyOf(原数组,要返回的数组长度)

案例

java 复制代码
public class Test01{
    public static void main(String [] args){


        int [] arr = {10,20,30,40};

        int [] newArr = Arrays.copyOf(arr,arr.length);


        //修改arr
        arr[1] = 100;  // 10  100  30  40 arr数组

        //打印arr
        for (int j : arr) {
            System.out.print(j + " "); //10  100  30  40 arr数组
        }

        System.out.println();

        //打印newArr
        for (int j : newArr) {
            System.out.print(j + " "); //10  20  30  40 newArr
        }
    }
}

输出:

5.使用Arrays.copyOfRange()方法

和copyOf()一样,内部也是用了arraycopy()。

方法原型:

java 复制代码
public static int[] copyOfRange(原数组,起始索引,结束索引)

案例:

java 复制代码
public class Test01{
    public static void main(String [] args){


        int [] arr = {10,20,30,40};

        int [] newArr = Arrays.copyOfRange(arr,0,arr.length);


        //修改arr
        arr[1] = 100;  // 10  100  30  40 arr数组

        //打印arr
        for (int j : arr) {
            System.out.print(j + " "); //10  100  30  40 arr数组
        }

        System.out.println();

        //打印newArr
        for (int j : newArr) {
            System.out.print(j + " "); //10  20  30  40 newArr
        }
    }
}

输出:

6.使用Object.clone()方法

数组调用.clone()方法达到深克隆效果

java 复制代码
public class Test01{
    public static void main(String [] args){


        int [] arr = {10,20,30,40};

        int [] newArr = arr.clone();


        //修改arr
        arr[1] = 100;  // 10  100  30  40 arr数组

        //打印arr
        for (int k : arr) {
            System.out.print(k + " "); //10  100  30  40 arr数组
        }

        System.out.println();

        //打印newArr
        for (int j : newArr) {
            System.out.print(j + " "); //10  20  30  40 newArr
        }
    }
}

输出:

相关推荐
JavaArchJourney1 分钟前
PriorityQueue 源码分析
java·源码
学行库小秘1 分钟前
基于门控循环单元的数据回归预测 GRU
人工智能·深度学习·神经网络·算法·回归·gru
喵手11 分钟前
你知道,如何使用Java的多线程机制优化高并发应用吗?
java·后端·java ee
_meow_16 分钟前
数学建模 15 逻辑回归与随机森林
算法·数学建模·逻辑回归
渣哥25 分钟前
10年Java老司机告诉你:为什么永远不要相信浮点数相等
java
1白天的黑夜135 分钟前
链表-24.两两交换链表中的结点-力扣(LeetCode)
数据结构·leetcode·链表
Faith-小浩浩1 小时前
macos 多个版本的jdk
java·macos·jdk
二向箔reverse1 小时前
机器学习算法核心总结
人工智能·算法·机器学习
喵手1 小时前
Java异常处理最佳实践:如何避免捕获到不必要的异常?
java·后端·java ee
猿java1 小时前
精通MySQL却不了解OLAP和 OLTP,正常吗?
java·后端·面试