当前位置: 首页 > news >正文

【Java】数组的深浅拷贝问题(二维数组举例)(136)

深拷贝和浅拷贝

对于数组来说,深拷贝就是相当于拷贝了数组的对象(基本数据类型),也就是数组当中的内容。而浅拷贝就是拷贝的是数组的地址(引用类型),浅拷贝只是复制了对象的引用地址,两个对象指向同一个内存地址,所以修改其中任意的值,另一个值都会随之变化。

数组的拷贝:数组拷贝有深拷贝和浅拷贝

深拷贝:一般使用Arrays.copyOf() 方法,,深拷贝修改新的数组不改变原数组。
浅拷贝:一般使用arr.clone() 方法,浅拷贝修改新数组和原数组。

深浅拷贝二维数组举例

package com.day02;

import java.util.Arrays;

public class day02 {
	public static void main(String[] args) {
		
		String[][] arr = {{"10","20"},{"30","40","50"},{"60","70","80","90"}};
		
		for (int i = 0; i < arr.length; i++) {
            for (int j = 0; j < arr[i].length; j++) {
                System.out.println("拷贝前原数组:"+arr[i][j]);
            }
        }
		
		System.out.println("--------------------------------------");
		
		//方式一:深拷贝二维数组(Arrays.copyOf):深拷贝修改新数组不改变原数组;
		String[][] arr2 = new String[arr.length][];
		
		for (int i = 0; i < arr2.length; i++) {
			arr2[i] = Arrays.copyOf(arr[i], arr[i].length);
        }
		
		for (int i = 0; i < arr2.length; i++) {
            for (int j = 0; j < arr2[i].length; j++) {
            	arr2[i][j] = arr2[i][j] + "%";
            }
        }
		for (int i = 0; i < arr2.length; i++) {
            for (int j = 0; j < arr2[i].length; j++) {
            	System.out.println("深拷贝后新数组:"+arr2[i][j]);
            }
        }
		System.out.println("---");
		for (int i = 0; i < arr.length; i++) {
            for (int j = 0; j < arr[i].length; j++) {
            	System.out.println("深拷贝后原数组:"+arr[i][j]);
            }
        }
		
		System.out.println("--------------------------------------");
		
		//方式二:浅拷贝二维数组(clone):浅拷贝修改新数组和原数组;
		
		String[][] arr3 = arr.clone();
		
		for (int i = 0; i < arr3.length; i++) {
            for (int j = 0; j < arr3[i].length; j++) {
            	arr3[i][j] = arr3[i][j] + "#";
            }
        }
		for (int i = 0; i < arr3.length; i++) {
            for (int j = 0; j < arr3[i].length; j++) {
            	System.out.println("浅拷贝后新数组:"+arr3[i][j]);
            }
        }
		System.out.println("---");
		for (int i = 0; i < arr.length; i++) {
            for (int j = 0; j < arr[i].length; j++) {
            	System.out.println("浅拷贝后原数组:"+arr[i][j]);
            }
        }
		
	}
}

测试输出:

拷贝前原数组:10
拷贝前原数组:20
拷贝前原数组:30
拷贝前原数组:40
拷贝前原数组:50
拷贝前原数组:60
拷贝前原数组:70
拷贝前原数组:80
拷贝前原数组:90
--------------------------------------
深拷贝后新数组:10%
深拷贝后新数组:20%
深拷贝后新数组:30%
深拷贝后新数组:40%
深拷贝后新数组:50%
深拷贝后新数组:60%
深拷贝后新数组:70%
深拷贝后新数组:80%
深拷贝后新数组:90%
---
深拷贝后原数组:10
深拷贝后原数组:20
深拷贝后原数组:30
深拷贝后原数组:40
深拷贝后原数组:50
深拷贝后原数组:60
深拷贝后原数组:70
深拷贝后原数组:80
深拷贝后原数组:90
--------------------------------------
浅拷贝后新数组:10#
浅拷贝后新数组:20#
浅拷贝后新数组:30#
浅拷贝后新数组:40#
浅拷贝后新数组:50#
浅拷贝后新数组:60#
浅拷贝后新数组:70#
浅拷贝后新数组:80#
浅拷贝后新数组:90#
---
浅拷贝后原数组:10#
浅拷贝后原数组:20#
浅拷贝后原数组:30#
浅拷贝后原数组:40#
浅拷贝后原数组:50#
浅拷贝后原数组:60#
浅拷贝后原数组:70#
浅拷贝后原数组:80#
浅拷贝后原数组:90#

相关文章:

  • SQL 如何提取多级分类目录
  • 从技能需求到就业前景,了解前端和后端开发的优缺点和个人选择
  • 数据结构——栈和队列
  • 【小余送书第一期】《数据要素安全流通》参与活动,即有机会中奖哦!!
  • 【蓝桥杯选拔赛真题62】Scratch判断小球 少儿编程scratch图形化编程 蓝桥杯选拔赛真题解析
  • Python中requirement 的使用
  • IntelliJ IDEA 左侧Commit栏不见了
  • 【面试题】有了Docker为啥还需要k8s?
  • MySQL之DML
  • 加速企业AI实施:成功策略和效率方法
  • 如何在Go中编写注释
  • 使用 FHE 实现加密大语言模型
  • SpringMVC 学习(七)JSON
  • 服务器补丁管理软件
  • elasticsearch 索引write.lock报错解决 —— 筑梦之路
  • 【JUC系列-08】深入理解CyclicBarrier底层原理和基本使用
  • 性能测试 —— Tomcat监控与调优:Jconsole监控
  • 八大排序详解
  • 禾观科技采用亚马逊云科技的数据湖,实现数据化驱动运营的核心
  • 油猴(篡改猴)学习记录
  • 对话地铁读书人|科研服务者岳先生:地铁适合浅阅读
  • 经济日报:“关税讹诈”拦不住中国制造升级
  • 接续驰援,中国政府援缅卫生防疫队出发赴缅
  • 在没有穹顶的剧院,和春天的音乐会来一场约会
  • 瑞安房地产王颖:房地产市场看到很好的信号,上海项目销售压力不大
  • 乌克兰和美国签署关于矿产协议的备忘录