简述: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());
image
泛型使用:
@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());
image
@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集合里面的数值。
image
注意:
@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());
image
@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());
image
网友评论