如何简化实体类代码

Spring boot使用Lombok编码

添加依赖

在 pom.xml 文件中添加相关依赖:java

<lombok.version>1.16.20</lombok.version>
 
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>${lombok.version}</version>
            <scope>provided</scope>
        </dependency>
 
 

  

安装插件

因为 Lombok 采起的注解形式的,在编译后,自动生成相应的方法,为了避免让 ide 疯了,须要下载插件了支持它。 
以 idea 为例:查找插件 lombok plugin 安装便可。api

用个人 User 实体类为例(set,get,toString 方法),ide

@Getter
@Setter
@ToString
public class SysUserEntity implements Serializable

  

在按快捷键 Ctrl + F12,能够查找到set,get,toString 方法。函数

注解

写点经常使用的,其他的 api 的打开 Jar 包一目了然ui

@Getter@Setter@ToString@EqualsAndHashCode构造函数
@AllArgsConstructor

会生成一个包含全部变量,同时若是变量使用了NotNull annotation , 会进行是否为空的校验, 
所有参数的构造函数的自动生成,该注解的做用域也是只有在实体类上,参数的顺序与属性定义的顺序一致。this

@NoArgsConstructor

无参构造函数编码

@RequiredArgsConstructor

会生成一个包含常量(final),和标识了@NotNull的变量 的构造方法。atom

怎么使用

它们都有三个参数能够设置 
1. String staticName() default "";idea

若是设置了它,将原来的构造方法的访问修饰符将会变成 私有的,而外添加一个静态构造方法,参数相同,名字是设置的字符串的名字,访问修饰符为公有的。spa

  1. AnyAnnotation[] onConstructor() default {}; 
    在构造方法上添加注解。使用方法@RequiredArgsConstructor(onConstructor=@__({@AnnotationsGoHere}))}

    例如咱们在 Spring 项目中须要注入多个值,写不少个 @Autowired 很麻烦,就可使用这种方式:

    @Service
    @RequiredArgsConstructor(onConstructor = @__(@Autowired))
    public class UserServiceImpl implements IUserService {
       private final IUserRepository userRepository;
       private final IOrderRepository orderRepository;
    

      

  2. AccessLevel access() default lombok.AccessLevel.PUBLIC; 
    构造函数访问修饰符;

  3. @NoArgsConstructor无参构造函数中还有个注解 boolean force() default false; 
    做者的注释是 If {@code true}, initializes all final fields to 0 / null / false. Otherwise, a compile time error occurs.

    设置为 true 的时候,初始化全部的参数为默认值,不然编译错误。

@Data

我本身尝试了下,咱们使用 @Data 注解就能够有下面几个注解的功能: @ToString@Getter@Setter@EqualsAndHashCode@NoArgsConstructor 。

注意的是,同时使用@Data 和 @AllArgsConstructor 后 ,默认的无参构造函数失效,若是须要它,要从新设置 @NoArgsConstructor

@Slf4j
  //类上面注解了,直接调用 log 便可:
log.info(xxxx);
 
 
@Log

使用的是 java.util.logging.Logger ,直接使用 变量 log

@Builder

bulder 模式构建对象。

@Cleanup
<wiz_code_mirror>
 
 
 
 
 
 
 
@Cleanup 
InputStream in = new FileInputStream(args[0]);
@Cleanup 
OutputStream out = new FileOutputStream(args[1]);
 
 

自动化关闭流,至关于 jdk1.7 种的 try with resource

val

类型推导。

<wiz_code_mirror>
 
 
 
 
 
 
 
 val example = new ArrayList<String>();
 example.add("Hello, World!");
 
 

对应的转换后代码就是:

<wiz_code_mirror>
 
 
 
 
 
 
 
 val example = new ArrayList<String>();
 example.add("Hello, World!");
 
 
@NonNull
<wiz_code_mirror>
 
 
 
 
 
 
 
public NonNullExample(@NonNull Person person) {
    this.name = person.getName();
 }
 
 

转换后就是:

<wiz_code_mirror>
 
 
 
 
 
 
 
public NonNullExample(@NonNull Person person) {
    if (person == null) {
      throw new NullPointerException("person");
    }
    this.name = person.getName();
 }
 
 
@SneakyThrows

翻译就是暗中抛出异常

当咱们须要抛出异常,在当前方法上调用,不用显示的在方法名后面写 throw

<wiz_code_mirror>
 
 
 
 
 
 
 
@SneakyThrows(Exception.class)
 
 
@Synchronized

方法中全部的代码都加入到一个代码块中,默认静态方法使用的是全局锁,普通方法使用的是对象锁,固然也能够指定锁的对象。

<wiz_code_mirror>
 
 
 
 
 
 
 
private final Object lock = new Object();
@Synchronized("lock")
public void foo() {
    // Do something
}
 
 

实际开发中每每将 synchronized 颗粒化到代码块中。

相关文章
相关标签/搜索