lombok翻车记录

发布时间 2023-07-07 02:58:22作者: 名泽

lombok翻车记录:

使用Lombok的Setter-Getter方法的注解,也就是组合注解@Data时

实体类的属性,首字母不应该小写,这会导致null,因为生成的Setter-Getter方法,是首字母大写的

解决方案

1.修改属性名字,让第二个字母小写,或者说是规定所有的属性的前两个字母必须小写
2.如果数据库已经设计好,并且前后端接口对接好了,不想修改,那就专门为这种特殊的属性使用idea生成get-set方法

EasyExcel与@Accessors(chain = true)不兼容分析

@Accessors 注解用来配置lombok如何产生和显示getters和setters的方法。

 

public @interface Accessors { /**

* 如果为true,则访问器将以该字段命名,并且不包含 get 或 set *前缀,且省略了chain,则 chain 默认为true。

* *默认值:false

*/ boolean fluent() default false; /**

* *如果为true,setter将返回this而不是void。

* *默认:false

 

当Excel每行数据解析后, 会调用 buildStringList 将解析到的数据由Map转存到Bean中, 关键代码如下:

BeanMap.create(resultModel).putAll(map);

可见, EasyExcel是使用 net.sf.cglib.beans.BeanMap 工具类拷贝的, 这正是造成 使用@Accessors(chain = true)后, EasyExcel解析不到数据的原因所在.

cglib使用到的方法:

if (int.class.equals(argTypes[0]) && name.startsWith(GET_PREFIX)) {
   pd = new IndexedPropertyDescriptor(this.beanClass, name.substring(3), null, null, method, null);
   //下面这行判断,只获取返回值是void类型的setxxxx方法
 } else if (void.class.equals(resultType) && name.startsWith(SET_PREFIX)) {
    // Simple setter
    pd = new PropertyDescriptor(this.beanClass, name.substring(3), null, method);
    if (throwsException(method, PropertyVetoException.class)) {
       pd.setConstrained(true);
    }
}

使用BeanMap从Map拷贝到Bean, 需要Map 的Key与Bean的变量名一致, 并有对应的 set方法, 且set方法为 void, 才能拷贝成功