@Builder使用

简述:Builder 使用创建者模式又叫建造者模式。简单来说,就是一步步创建一个对象,它对用户屏蔽了里面构建的细节,但却可以精细地控制对象的构造过程。
使用:一般单独进行使用,如果需要和@Data一起使用,为避免造成不必要错误。推荐下面四个注解一起使用。

@Builder
@Data
@AllArgsConstructor
@NoArgsConstructor

简单使用:

注意:对于目标类中的所有的属性和未初始化的final字段,才会在构建器中创建对应属性。(所以下面没有.code()赋值)

@Builder
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private final Integer code = 200;
    private String username;
    private String password;
}
System.out.println(User.builder().username("hecc").password("hecc").build());

泛型使用:

@Builder
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User<T> {
    private final Integer code = 200;
    private String username;
    private String password;
    private List<T> roles;
}
System.out.println(User.<String>builder().username("hecc").password("hecc").role(Lists.newArrayList("admin")).build());

@Builder中使用 @Singular 注释集合

@Builder
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private final Integer code = 200;
    private String username;
    private String password;
    @Singular
    private List<String> roles;
}
//不添加
System.out.println(User.builder().username("hecc").password("hecc").build());
//单个添加
System.out.println(User.builder().username("hecc").password("hecc").role("admin").build());
//多次单个添加
System.out.println(User.builder().username("hecc").password("hecc").role("admin").role("read").build());
//一次性添加多个
System.out.println(User.builder().username("hecc").password("hecc").roles(Lists.newArrayList("admin","read")).build());
//搭配使用
System.out.println(User.builder().username("hecc").password("hecc").role("test").roles(Lists.newArrayList("admin","read")).build());
//还有个clearRoles()可以清空List集合里面的数值。


注意:
@Singular注解添加的额外方法使用的是集合名的单数形式。
例如:childrenInfos会生成childrenInfo;glasses会生成glass;children会生成child。
有时候属性名不规范或者无法识别时,@Singular就不知道生成啥样的,这个时候编译就报错,提示你:

Can’t singularize this name: “ssss”; please specify the singular explicitly (i.e. @Singular(“sheep”))

解决办法:
1.规范命名,采用复数,比如roles。
2.@Singular(value="XXX"),给单个添加取个别名,这样你取的XXX就是单个添加的,被注解修饰的就是集合形式添加的。

@Singular注解的value属性,可以更改调用的方法名,如:

@Singular(value = "test")
private List<String> roles;

这样就是用.test("admin")赋值了,但是注意:添加一个集合的方法名没有发生改变,还是.roles(List集合)

        System.out.println(User.builder().username("hecc").password("hecc").test("admin").roles(Lists.newArrayList("test")).build());

@Builder.Default 的使用

在类中我在id和insertTime上都添加注解@Builder.Default,当我在使用这个实体对象时,我就不需要在为这两个字段进行初始化值。如果赋值,就会覆盖原有的赋值。

@Builder
@Data
@AllArgsConstructor
@NoArgsConstructor
public class User {
    private final Integer code = 200;
    private String username;
    private String password;
    @Singular(value = "test")
    private List<String> roles;
    @Builder.Default
    private String id = UUID.randomUUID().toString();
    @Builder.Default
    private long insertTime = System.currentTimeMillis();
}
System.out.println(User.builder().username("hecc").password("hecc").test("admin").build());
System.out.println(User.builder().username("hecc").password("hecc").test("admin").id("admin").insertTime(123).build());





具体细节强烈推荐查看这篇文章:https://blog.csdn.net/weixin_41540822/article/details/86606562

posted @ 2022-11-30 14:23  chandol  阅读(1002)  评论(0编辑  收藏  举报