Spring下的BeanUtils.copyProperties方法是深拷贝还是浅拷贝?可以实现深拷贝吗? | 您所在的位置:网站首页 › beanutils是深拷贝吗 › Spring下的BeanUtils.copyProperties方法是深拷贝还是浅拷贝?可以实现深拷贝吗? |
这里写目录标题
BeanUtils.copyProperties中的拷贝
BeanUtils.copyProperties是浅拷贝还是深拷贝?
建立两个类用来测试BeanUtils.copyProperties:
1.CityBean
2.FastdfsTest
测试方法:
测试截图:
如何用BeanUtils.copyProperties实现深拷贝
测试代码
测试截图
深拷贝模板
BeanUtils.copyProperties中的拷贝 简单说拷贝就是将一个类中的属性拷贝到另一个中,对于BeanUtils.copyProperties来说,你必须保证属性名是相同的,因为它是根据get和set方法来赋值的。 浅拷贝可以理解为如果是引用类型,那么目标对象拷贝的只是源对象的地址,无论目标对象还是源对象改变,他们都会一起改变 深拷贝就是将目标对象的属性全部复制一份给源对象,复制完之后他们就是隔开的,没有任何关系,无论操作源对象还是目标对象都对另一个没有影响 无论是浅拷贝还是深拷贝,对于基本类型和String来说都是没有影响的,有影响的只有引用类型数据 个人理解,通过下面的代码也许你会跟我一样开始认为,网上深浅拷贝的定义是没有问题的,但是对于很多方法,说方法是深浅拷贝是有问题的。具体让我们来看代码吧!BeanUtils.copyProperties是浅拷贝还是深拷贝? 浅拷贝 建立两个类用来测试BeanUtils.copyProperties: 1.CityBean 1234public class CityBean { String value; .......// 省略get和set方法,Alt+insert很快的 } 2.FastdfsTest 1234567public class FastdfsTest { private String id; private String name; private String size; private CityBean cityBean; .......// 省略get和set方法,Alt+insert很快的 测试方法: 12345678910111213141516171819202122 @Test public void testObjectMapper() throws IOException, MyException { // 源类 FastdfsTest source = new FastdfsTest(); source.setId("fastdfsTest"); source.setName("fastdfsTest"); source.setSize("fastdfsTest"); CityBean cityBean = new CityBean(); cityBean.setValue("CityBean源值"); source.setCityBean(cityBean); // 目标类 FastdfsTest target = new FastdfsTest(); // 把fastdfsTest中所有的属性都复制到fastdfsTestCopy中,即使是cityBean也会被复制 BeanUtils.copyProperties(source,target); CityBean sourceCity = source.getCityBean(); //在下面改变源类的引用数据,如果BeanUtils.copyProperties是浅拷贝,那么目标类拷贝的就是一个引用地址;源类改变目标类也会跟着改变 //如果BeanUtils.copyProperties是深拷贝,则两边改变都不会相互影响 sourceCity.setValue("CityBean目标值"); System.out.println(source.toString() == target.toString()); } 测试截图:这里可以看出BeanUtils.copyProperties是一个浅拷贝 如何用BeanUtils.copyProperties实现深拷贝 测试代码 123456789101112131415161718192021222324252627/** * 测试stream中用BeanUtils.copyProperties是否是深拷贝 */ @Test public void testStream(){ // 我从数据库查的,其实就是创建几个数据,这里就自己添加了哈 List fastdfsTestList = fastdfsTestService.selectFastdfsTestList(); // 先构造 fastdfsTestList = fastdfsTestList.stream().map(k -> { CityBean cityBean = new CityBean(); cityBean.setValue("新的value"); k.setCityBean(cityBean); return k; }).collect(Collectors.toList()); // 拷贝 List fastdfsTestList2 = fastdfsTestList.stream().map(k -> { FastdfsTest fastdfsTest = new FastdfsTest(); BeanUtils.copyProperties(k,fastdfsTest); return fastdfsTest; }).collect(Collectors.toList()); // 设置源对象引用字段为空 fastdfsTestList.get(0).setCityBean(null); System.out.println(fastdfsTestList + "==userDTOList==" + fastdfsTestList2); } 测试截图这里可以看到改变源对象是不会影响目标对象的,因此可以借助java8的一些stream新特性,用BeanUtils.copyProperties这个方法来实现深拷贝(任意两个类都可以哦) 深拷贝模板 123456// 拷贝 List target= source.stream().map(k -> { 目标类型 xxx= new 目标类型(); BeanUtils.copyProperties(k,xxx); return xxx; }).collect(Collectors.toList()); |
CopyRight 2018-2019 实验室设备网 版权所有 |