Spring的BeanUtils的copyProperties方法需要注意的点

public List<CopyTest1.InnerClass> clazz;

@ToString

@Data

public static class InnerClass {

public String InnerName;

}

}

目标类:

@ToString

@Data

public class CopyTest2 {

public String outerName;

public CopyTest2.InnerClass innerClass;

public List<CopyTest2.InnerClass> clazz;

@ToString

@Data

public static class InnerClass {

public String InnerName;

}

}

测试代码:

CopyTest1 test1 = new CopyTest1();

test1.outerName = “hahaha”;

CopyTest1.InnerClass innerClass = new CopyTest1.InnerClass();

innerClass.InnerName = “hohoho”;

test1.innerClass = innerClass;

System.out.println(test1.toString());

CopyTest2 test2 = new CopyTest2();

BeanUtils.copyProperties(test1, test2);

System.out.println(test2.toString());

这里遇到了第一个坑,一开始图省事,属性写为public,想着省掉了getter和setter方法,没加@Data注解,结果运行完test2所有属性都为null,一个都没copy过去,加上@Data继续跑,果然,基本属性(String)复制过去了,但是内部类在test2中还是null。那就验证了真的是内部类的问题,有点不敢相信自己的眼睛,毕竟线上跑了这么久的代码。。。

知道了问题,总要想着怎么解决吧,所以需要单独设置一下内部类,单独copy,如果内部类的bean属性较多或者递归的bean属性很多,那可以自己封装一个方法,用于递归拷贝,我这里只有一层,所以直接额外copy一次

CopyTest1 test1 = new CopyTest1();

test1.outerName = “hahaha”;

CopyTest1.InnerClass innerClass = new CopyTest1.InnerClass();

innerClass.InnerName = “hohoho”;

test1.innerClass = innerClass;

System.out.println(test1.toString());

CopyTest2 test2 = new CopyTest2();

test2.innerClass = new CopyTest2.InnerClass();

BeanUtils.copyProperties(test1, test2);

BeanUtils.copyProperties(test1.innerClass, test2.innerClass);

System.out.println(test2.toString());

记得内部类的属性也是要有setter方法的,不然也会导致copy失败,大家还记得我开头说到还有两个List属性的吧,为什么要提到这个呢?你猜

其实list里面的两个类也都是重写的内部类,他们也是不同的,当时他们却顺利copy过去了,为什么呢?因为java的泛型只在编译期起作用,在运行期,list属性就是一个存放Object的集合,在copy后,MixAddRequest的orders属性其实是一个Order类的集合,但却不是自己内部类的集合,是AddRequest的内部类Order的集合,但因为对方是解析json的,所以没有发生错误。。。

总结

  1. Spring的BeanUtils的CopyProperties方法需要对应的属性有getter和setter方法;

  2. 如果存在属性完全相同的内部类,但是不是同一个内部类,即分别属于各自的内部类,则spring会认为属性不同,不会copy;

  3. 泛型只在编译期起作用,不能依靠泛型来做运行期的限制;

  4. 最后,spring和apache的copy属性的方法源和目的参数的位置正好相反,所以导包和调用的时候都要注意一下。

最后的最后


附上spring的源码,getWriteMethod是jdk的方法,会去取set开头的方法,所以没有setter方法是不行滴。

private static void copyProperties(Object source, Object target, @Nullable Class<?> editable, @Nullable String… ignoreProperties) throws BeansException {

Assert.notNull(source, “Source must not be null”);

Assert.notNull(target, “Target must not be null”);

Class<?> actualEditable = target.getClass();

if (editable != null) {

if (!editable.isInstance(target)) {

throw new IllegalArgumentException(“Target class [” + target.getClass().getName() + “] not assignable to Editable class [” + editable.getName() + “]”);

}

actualEditable = editable;

}

PropertyDescriptor[] targetPds = getPropertyDescriptors(actualEditable);

List ignoreList = ignoreProperties != null ? Arrays.asList(ignoreProperties) : null;

PropertyDescriptor[] var7 = targetPds;

int var8 = targetPds.length;

for(int var9 = 0; var9 < var8; ++var9) {

PropertyDescriptor targetPd = var7[var9];

Method writeMethod = targetPd.getWriteMethod();

if (writeMethod != null && (ignoreList == null || !ignoreList.contains(targetPd.getName()))) {

总结:绘上一张Kakfa架构思维大纲脑图(xmind)

image

其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?

若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理

梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。

  • Kafka入门

  • 为什么选择Kafka

  • Kafka的安装、管理和配置

  • Kafka的集群

  • 第一个Kafka程序

  • Kafka的生产者

  • Kafka的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

  • 数据管道和流式处理(了解即可)

image

image

ka程序

  • Kafka的生产者

  • Kafka的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

  • 数据管道和流式处理(了解即可)

[外链图片转存中…(img-fo2UER3h-1721158122966)]

[外链图片转存中…(img-xfc9q9br-1721158122967)]

  • 24
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用BeanUtils.copyProperties需要注意以下几: 1. 类型匹配:源对象和目标对象的属性类型必须匹配或可转换。如果类型不匹配,会抛出类型转换异常。 2. 属性名匹配:源对象和目标对象的属性名必须一致。如果属性名不一致,可以使用@PropertyName注解或者自定义转换器来处理。 3. 空值处理:默认情况下,如果源对象的属性值为null,目标对象对应的属性值也会被设置为null。如果不希望设置为null,可以使用BeanUtils.copyProperties(Object, Object, String[])方法,并指定需要忽略的属性。 4. 性能问题:BeanUtils.copyProperties使用反射实现,对于大量调用会有性能问题。如果需要处理大量对象的属性复制,可以考虑使用其他替代方案,如BeanMapper。 5. 异常处理:BeanUtils.copyProperties可能会抛出IllegalAccessException和InvocationTargetException异常。在使用时需要进行异常处理。 范例:<<引用:org.apache.commons.beanutils.BeanUtils.copyProperties(); 。 引用:一个BeanUtils.copyProperties的小型快速替代。 起因 由于BeanUtilsSpring或Apache Commons)的copyProperties实现是利用反射实现的,它在大量调用时具有比较严重的性能问题。 BeanMapper通过javassist类库实现在...。 请回答我或者给我介绍或演示一下:使用BeanUtils.copyProperties有什么注意? 使用BeanUtils.copyProperties需要注意以下几: 1. 类型匹配 2. 属性名匹配 3. 空值处理 4. 性能问题 5. 异常处理
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值