当前位置: 首页 > 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监控
  • 八大排序详解
  • 禾观科技采用亚马逊云科技的数据湖,实现数据化驱动运营的核心
  • 油猴(篡改猴)学习记录
  • 五问舆论漩涡中的“协和‘4+4’模式”:是否公平,如何合格?
  • 巴菲特批评贸易保护主义:贸易不该被当成武器来使用
  • 跳水世界杯总决赛:程子龙/朱子锋夺男子双人10米台冠军
  • 网红“丢那猩”丢石块闯祸,起哄游客难逃责任
  • 李在明涉嫌违反《公职选举法》案将于15日进行首次重审公审
  • 安徽六安特色产品将“组团”入沪,借力五五购物节开拓市场