开发工具Tools·Lombok

作者 : jamin 本文共2513个字,预计阅读时间需要7分钟 发布时间: 2020-10-18 共1105人阅读

Lombok

记录 Lombok 中常见的一些注解。

Builder

Java    构造模式:

@Data
public class User {
    private Integer id;
    private String name;
    private String address;

    private User() {
    }

    private User(User origin) {
        this.id = origin.id;
        this.name = origin.name;
        this.address = origin.address;
    }

    public static class Builder {
        private User target;

        public Builder() {
            this.target = new User();
        }

        public Builder id(Integer id) {
            target.id = id;
            return this;
        }

        public Builder name(String name) {
            target.name = name;
            return this;
        }

        public Builder address(String address) {
            target.address = address;
            return this;
        }

        public User build() {
            return new User(target);
        }
    }
}

使用方式:

User user = new User.Builder().id(1).name("Nicestar").address("chan").build();

使用 @Builder 注解可以很方便实现建造者模式:

@Data
@Builder
public class User {
    private Integer id;
    private String name;
    private String address;
}

使用方式:

User user = User.builder().id(1).name("Nicestar").address("chan").build();

如果属性字段有默认值,需要加上 @Builder.Default 注解:

@Builder.Default
private String name = "Nicestar1";

@AllArgsConstructor、@NoArgsConstructor、@RequiredArgsConstructor(staticName = “of”)

如果要给实体类生成构造方法:

  • @AllArgsConstructor 用来指定全参数构造器
  • @NoArgsConstructor 用来指定无参数构造器
  • @RequiredArgsConstructor 给所有带有 @NonNull 注解的或者带有 final 修饰的成员变量生成对应的构造方法,使用静态方法调用
@Data
@AllArgsConstructor
@NoArgsConstructor
@RequiredArgsConstructor(staticName = "of")
public class User {
    private Integer id;
    private String name;
    @NonNull private String address;
}

使用方式:

User user1 =new User(); // 无参构造器
User user2 =new User(1, "Nicestar", "chan"); // 全参构造器
User user3 = User.of("chan"); // `@NonNull` 和 `final` 参数构造器

使用 @RequiredArgsConstructor(onConstructor = @__(@Autowired)) 注解可以给所有 private final 字段提供自动注入。

@Accessors

使用 @Accessors(chain = true) 注解实现链式调用:

@Data
@Accessors(chain = true)
public class User {
    private Integer id;
    private String name;
    private String address;
}

使用方式:

User user = new User().setId(2).setName("Nicestar").setAddress("chan");

也可以配合上面的 @RequiredArgsConstructor 使用:

@Data
@Accessors(chain = true)
@RequiredArgsConstructor(staticName = "of")
public class User {
    private Integer id;
    private String name;
    @NonNull private String address;
}

使用方式:

User user = User.of("chan").setId(2).setName("Nicestar");

@Data

@Data 注解是 @ToString@EqualsAndHashCode@Getter@Setter@RequiredArgsConstructor 注解的集合。代替 RequiredArgsConstructor 使用时:

@Data
@Data(staticConstructor="of")
public class User {
    private Integer id;
    private String name;
    @NonNull private String address;
}

@NonNull

注解在属性上,会自动产生一个关于此参数的非空检查,如果参数为空,则抛出一个空指针异常。

@Cleanup

这个注解用在变量前面,可以保证此变量代表的资源会被自动关闭,默认是调用资源的 close() 方法,如果该资源有其它关闭方法,可使用 @Cleanup(“methodName”) 来指定要调用的方法,也会生成默认的构造方法

public static void main(String[] args) throws IOException {

    @Cleanup InputStream in = new FileInputStream(args[0]);
}

@ToString(callSuper = true)

解决子类 toString 方法不打印父类属性:

@ToString(callSuper = true)
本站所提供的部分资源来自于网络,版权争议与本站无关,版权归原创者所有!仅限用于学习和研究目的,不得将上述内容资源用于商业或者非法用途,否则,一切后果请用户自负。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源。如果上述内容资对您的版权或者利益造成损害,请提供相应的资质证明,我们将于3个工作日内予以删除。本站不保证所提供下载的资源的准确性、安全性和完整性,源码仅供下载学习之用!如用于商业或者非法用途,与本站无关,一切后果请用户自负!本站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。如有侵权、不妥之处,请联系站长以便删除!
金点网络 » 开发工具Tools·Lombok

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。
是否提供免费更新服务?
持续更新,永久免费
是否经过安全检测?
安全无毒,放心食用

提供最优质的资源集合

立即加入 友好社区
×