Lombok中@Builder注解的功能及示例简介说明
下文笔者讲述@Builder注解的功能及示例简介说明,如下所示
Builder注解的功能
@Builder注解常用于实体类上
当在实体类上加入Builder注解上时,
则属性赋值则可以使用Builder模式
增加赋值set的便利性
Builder注解的使用步骤:
1.引入相应的jar包
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
</dependency>
2.实体类上加入Builder注解
@Builder注解示例
//实体类
@Builder
@Getter
@ToString
public class User {
private String name;
private Integer age;
}
public class TestBuilder {
public static void main(String[] args) {
// 使用Builder注解来创建一个User实例
User test = User.builder()
.age(18)
.name("java265").build();
System.out.println(test);
/**
* 修改原对象的属性值
* 注意: 修改实体, 要在实体的@Builder注解里面设置toBuilder = true
* toBuilder的默认值是false,这个可以自行去查看@Builder注解类的实现
* 里面有这样一行代码:
* boolean toBuilder() default false;
*/
test = test.toBuilder()
.age(22).build();
System.out.println(test);
}
}
----运行以上代码,将输出以下信息-----
User(name=java265, age=18)
User(name=java265, age=22)
@Builder注解后的源码
public class User {
private String name;
private Integer age;
User(String name, Integer age) {
this.name = name;
this.age = age;
}
public static User.UserBuilder builder() {
return new User.UserBuilder();
}
public String getName() {
return this.name;
}
public Integer getAge() {
return this.age;
}
public String toString() {
return "User(name=" + this.getName() + ", age=" + this.getAge() + ")";
}
public static class UserBuilder {
private String name;
private Integer age;
UserBuilder() {
}
public User.UserBuilder name(String name) {
this.name = name;
return this;
}
public User.UserBuilder age(Integer age) {
this.age = age;
return this;
}
public User build() {
return new User(this.name, this.age);
}
public String toString() {
return "User.UserBuilder(name=" + this.name + ", age=" + this.age + ")";
}
}
}
Builder实现原理
1.创建 一个名UserBuilder的静态内部类 和实体类相同的属性(称为构建器) 在构建器中: 对于目标类中的所有的属性,都会在构建器中创建对应的属性 在构建器中: 创建一个无参的default构造方法 在构建器中: 对于实体类中的每个参数, 都会对应创建类似于setter方法, 但是方法名是与该参数名是相同 且返回值是构建器本身(便于链式调用) 在构建器中: 一个build方法 调用此方法 就会根据设置的值进行创建对象实例 在构建器中: 同时也会生成一个toString()方法 在构建器中: 会创建一个builder()方法 用于创建构建器
版权声明
本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。


