This commit is contained in:
Looly 2022-03-29 00:13:00 +08:00
parent 8683caaad0
commit 64fdf75fc6
3 changed files with 42 additions and 14 deletions

View File

@ -2,9 +2,10 @@
# 🚀Changelog # 🚀Changelog
------------------------------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------------------------------
# 5.8.0.M2 (2022-03-28) # 5.8.0.M2 (2022-03-29)
### ❌不兼容特性 ### ❌不兼容特性
* 【extra 】 【可能兼容问题】BeanCopierCache的key结构变更
### 🐣新特性 ### 🐣新特性

View File

@ -29,24 +29,37 @@ public enum BeanCopierCache {
* @return Map中对应的BeanCopier * @return Map中对应的BeanCopier
*/ */
public BeanCopier get(Class<?> srcClass, Class<?> targetClass, Converter converter) { public BeanCopier get(Class<?> srcClass, Class<?> targetClass, Converter converter) {
final String key = genKey(srcClass, targetClass, converter); return get(srcClass, targetClass, null != converter);
return cache.get(key, () -> BeanCopier.create(srcClass, targetClass, converter != null));
} }
/** /**
* 获得类与转换器生成的key * 获得类与转换器生成的key{@link BeanCopier}的Map中对应的元素
* *
* @param srcClass 源Bean的类 * @param srcClass 源Bean的类
* @param targetClass 目标Bean的类 * @param targetClass 目标Bean的类
* @param converter 转换器 * @param useConverter 是否使用转换器
* @return Map中对应的BeanCopier
* @since 5.8.0
*/
public BeanCopier get(Class<?> srcClass, Class<?> targetClass, boolean useConverter) {
final String key = genKey(srcClass, targetClass, useConverter);
return cache.get(key, () -> BeanCopier.create(srcClass, targetClass, useConverter));
}
/**
* 获得类与转换器生成的key<br>
* 结构类似于srcClassName#targetClassName#1 或者 srcClassName#targetClassName#0
*
* @param srcClass 源Bean的类
* @param targetClass 目标Bean的类
* @param useConverter 是否使用转换器
* @return 属性名和Map映射的key * @return 属性名和Map映射的key
*/ */
private String genKey(Class<?> srcClass, Class<?> targetClass, Converter converter) { private String genKey(Class<?> srcClass, Class<?> targetClass, boolean useConverter) {
final StringBuilder key = StrUtil.builder() final StringBuilder key = StrUtil.builder()
.append(srcClass.getName()).append('#').append(targetClass.getName()); .append(srcClass.getName())
if(null != converter){ .append('#').append(targetClass.getName())
key.append('#').append(converter.getClass().getName()); .append('#').append(useConverter ? 1 : 0);
}
return key.toString(); return key.toString();
} }
} }

View File

@ -1,5 +1,6 @@
package cn.hutool.extra.cglib; package cn.hutool.extra.cglib;
import cn.hutool.core.convert.Convert;
import lombok.Data; import lombok.Data;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
@ -9,23 +10,36 @@ public class CglibUtilTest {
@Test @Test
public void copyTest() { public void copyTest() {
SampleBean bean = new SampleBean(); SampleBean bean = new SampleBean();
bean.setValue("Hello world");
OtherSampleBean otherBean = new OtherSampleBean(); OtherSampleBean otherBean = new OtherSampleBean();
bean.setValue("Hello world");
bean.setValue2("123");
CglibUtil.copy(bean, otherBean); CglibUtil.copy(bean, otherBean);
Assert.assertEquals("Hello world", otherBean.getValue()); Assert.assertEquals("Hello world", otherBean.getValue());
// 无定义转换器转换失败
Assert.assertEquals(0, otherBean.getValue2());
OtherSampleBean otherBean2 = CglibUtil.copy(bean, OtherSampleBean.class); OtherSampleBean otherBean2 = CglibUtil.copy(bean, OtherSampleBean.class);
Assert.assertEquals("Hello world", otherBean2.getValue()); Assert.assertEquals("Hello world", otherBean2.getValue());
// 无定义转换器转换失败
Assert.assertEquals(0, otherBean.getValue2());
otherBean = new OtherSampleBean();
//自定义转换器
CglibUtil.copy(bean, otherBean, (value, target, context) -> Convert.convertQuietly(target, value));
Assert.assertEquals("Hello world", otherBean.getValue());
Assert.assertEquals(123, otherBean.getValue2());
} }
@Data @Data
public static class SampleBean { public static class SampleBean {
private String value; private String value;
private String value2;
} }
@Data @Data
public static class OtherSampleBean { public static class OtherSampleBean {
private String value; private String value;
private int value2;
} }
} }