Java中使用Lombok

简介

Lombok是一种Java的实用工具,可以帮助开发人员消除Java的冗长,尤其是对于简单的Java对象(POJO),它通过注释实现这一目的;一个标准的Java bean 一般具有若干个属性,每个属性具有getter()和setter方法,Lombok中也用到了注解,但是它并没有用到反射,而是通过一些奇技能淫巧,在代码编译时期动态将注解替换成具体的代码,所以JVM实际运行的代码,和我们手动编写的包含了各种工具方法的类相同

使用

使用前提

这里我是在idea中使用的,首先我们来安装插件
File—>Settings—>Plugins 然后再搜索Lombok
在这里插入图片描述
添加依赖

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.16.16</version>
</dependency>

注解的介绍

  1. @val: 注解在属性前面,声明一个final的变量(可以不声明类型)
  2. @var:与val差不多,但没有用final声明
  3. @Data: 注解在类上,将类提供的所有属性都添加get,set方法,并添加,equals,canEquals,hashCode,toString方法
  4. @Getter: 注解在类上,为所有的属性添加get方法,注解在属性上为该属性提供get方法
  5. @Setter: 注解在类上,为所有的属性添加set方法,注解在属性上为该属性提供set方法
  6. @NotNull: 在参数中使用时,如果调用时传了null值,就会抛出空指针异常
  7. @Synchronized: 用于方法,可以锁定指定的对象,如果不指定,则默认创建一个对象锁定
  8. @Log: 作用于类,创建一个log属性
  9. @Builder: 使用builder模式创建对象
  10. @NoArgsConstructor: 创建一个无参构造函数
  11. @AllArgsConstructor: 创建一个全参构造函数
  12. @ToString: 创建一个toString方法
  13. @Accessors(chain = true)使用链式设置属性,set方法返回的是this对象
  14. @RequiredArgsConstructor: 创建对象,例:在class上添加@RequiredArgsConstructor(staticName = “of”)会创建生成一个静态方法
  15. @UtilityClass: 工具类
  16. @ExtensionMethod: 设置父类
  17. @FieldDefaults: 设置属性的使用范围,如private,public等,也可以设置属性是否被final修饰
  18. @Cleanup: 关闭流,连接点
  19. @EqualsAndHashCode: 重写equals和hashcode方法
  20. @toString: 创建toString方法
  21. @Cleanup: 用于流等可以不需要关闭使用流对象

使用的例子

val

在这里插入图片描述
可以看到可以正常编译,但运行的时候就检测到了并且报错了

@Getter

package com.jbit.entity;

import lombok.Getter;

@Getter
public class User {
    private String id;
    private String name;
    private Integer age;

    public static void main(String[] args) {
        User user = new User();
        System.out.println(user.getAge());
    }
}

在这里插入图片描述

@Setter

package com.jbit.entity;

import lombok.Getter;
import lombok.Setter;

@Getter
@Setter
public class User {
    private String id;
    private String name;
    private Integer age;

    public static void main(String[] args) {
        User user = new User();
        user.setAge(10);
        System.out.println(user.getAge());
    }
}

在这里插入图片描述

@Data

package com.jbit.entity;

import lombok.Data;

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

    public static void main(String[] args) {
        User user = new User();
        user.setAge(10);
        user.setName("张三");
        System.out.println(user.getAge());
        System.out.println(user.toString());
    }
}

在这里插入图片描述

@Accessors(chain = true):使用链式创建

package com.jbit.entity;

import lombok.Data;
import lombok.experimental.Accessors;

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

    public static void main(String[] args) {
        User user = new User();
        user.setId("1").setName("chain").setAge(1);
        System.out.println(user.toString());
    }
}

在这里插入图片描述

@Builder:使用builder模式创建对象

package com.jbit.entity;

import lombok.Builder;
import lombok.Data;

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

    public static void main(String[] args) {
        User user =  User.builder().id("1").name("builder").age(1).build();
        System.out.println(user.toString());
    }
}

在这里插入图片描述
@UtilityClass: 工具类注解

package com.jbit.entity;

import lombok.experimental.UtilityClass;

@UtilityClass
public class Utility {

    public String getName(){
        return "name";
    }

    public static void main(String[] args) {
        System.out.println(Utility.getName());
    }
}

在这里插入图片描述
参考链接:https://www.jianshu.com/p/2ea9ff98f7d6

Java中引入Lombok库是为了简化代码,它通过注解自动处理一些常见的 boilerplate 代码生成。以下是引入Lombok到项目中的步骤: 1. **添加Maven依赖**(如果你使用Maven): 在项目的`pom.xml`文件中添加Lombok的仓库和版本信息: ```xml <dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId:lombok</artifactId> <version>最新版本号</version> <optional>true</optional> <!-- Maven默认不会包含lombok,所以加上这行 --> </dependency> </dependencies> ``` 记得替换`最新版本号`为实际的Lombok版本。 2. **Gradle配置**(如果你使用Gradle): 在`build.gradle`文件中添加依赖: ```groovy dependencies { implementation 'org.projectlombok:lombok:$lombok_version' } ``` 同样需要替换`$lombok_version`为实际版本。 3. **启用Lombok**(有些IDE如IntelliJ IDEA、Eclipse等需要额外设置): - IntelliJ IDEA:安装并启用Lombok插件(Idea Plugin Manager),然后右键单击项目 -> Properties -> Languages and Frameworks -> Java -> Annotation Processors -> Enable annotation processing。 - Eclipse:在Project Structure > Configure Build Tools 中找到Annotation processors,勾选lombok.org Lombok,并重启IDE。 4. **编译前处理**(如果IDE不支持自动处理): 你需要在编译前运行Lombok的注解处理器,这通常在构建脚本(如Ant或Maven的pre-compile阶段)中完成。 现在,你可以在项目中开始使用Lombok提供的注解了,比如`@Getter`、`@Setter`、`@NoArgsConstructor`等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值