Java浅Copy的一些事

栏目: Java · 发布时间: 7年前

内容简介:最近发现了一个现象:用调研了于是乎就换了一个种方式来写:

最近发现了一个现象:用 BeanUtils.copyProperties(Object source, Object target) 时, 如果source和target中有 List 对象,然后修改了source的 List 对象中的元素,发现target的 List 对象也会跟着变化。

调研了 BeanUtils.copyProperties(Object source, Object target) 源码,发现是通过 method.invoke 方法来实现属性的copy的,所以对象的属性复制都是浅Copy。

于是乎就换了一个种方式来写:

List<A> source = new ArrayList<>();
source.add(new A());
List<A> copy = new ArrayList<>(source);
复制代码

发现居然还是不行!

觉得很奇怪,然后看了 ArrayList 的构造方法,

public ArrayList(Collection<? extends E> c) {
        elementData = c.toArray();
        if ((size = elementData.length) != 0) {
            // c.toArray might (incorrectly) not return Object[] (see 6260652)
            if (elementData.getClass() != Object[].class)
                elementData = Arrays.copyOf(elementData, size, Object[].class);
        } else {
            // replace with empty array.
            this.elementData = EMPTY_ELEMENTDATA;
        }
    }
复制代码

elementData = c.toArray() 这段代码还是浅Copy。

思考了一会,难道只能通过遍历元素,然后添加元素的方式来解决吗?抱着疑问去Google了下,发现该函数 Collections.copy 解决了问题,进入其源码发现是在遍历元素然后再添加。。。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JavaScript从入门到精通

JavaScript从入门到精通

明日科技 / 清华大学出版社 / 2012-9 / 69.80元

《JavaScript从入门到精通》从初学者角度出发,通过通俗易懂的语言、丰富多彩的实例,详细介绍了使用JavaScript语言进行程序开发应该掌握的各方面技术。全书共分24章,包括初识JavaScript、JavaScript基础、流程控制、函数、JavaScript对象与数组、字符串与数值处理对象、正则表达式、程序调试与错误处理、事件处理、处理文档(document对象)、文档对象模型(DOM......一起来看看 《JavaScript从入门到精通》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具