内容简介:最近发现了一个现象:用调研了于是乎就换了一个种方式来写:
最近发现了一个现象:用 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从入门到精通
明日科技 / 清华大学出版社 / 2012-9 / 69.80元
《JavaScript从入门到精通》从初学者角度出发,通过通俗易懂的语言、丰富多彩的实例,详细介绍了使用JavaScript语言进行程序开发应该掌握的各方面技术。全书共分24章,包括初识JavaScript、JavaScript基础、流程控制、函数、JavaScript对象与数组、字符串与数值处理对象、正则表达式、程序调试与错误处理、事件处理、处理文档(document对象)、文档对象模型(DOM......一起来看看 《JavaScript从入门到精通》 这本书的介绍吧!