java maven项目使用lombok

1、首先要将IDE工具安装lombok的插件,才会对编译不出问题;

      1-1、如果是eclipse的话,需要在官网下载jar文件,放到eclipse根目录下,eclipse.ini的最后追加 

-Xbootclasspath/a:lombok.jar
-javaagent:lombok.jar
 

      1-2、如果是IDEA的话,需要在Setting > Plugins > Browse repositories... 下载lombok插件。

2、在pom.xml中追加

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.4</version>
            <scope>provided</scope>
        </dependency>

3、然后所有实体类、DTO中的Getter、Setter、ToString方法(全属性)、HashCode和equals方法(全属性)都不再需要,用@Getter、@Setter、@ToString、@EqualsAndHashCode代替。

当然,这些注解太多了, 可以直接用  @Data 注解来直接替换,就可以将上边的所有注解功能实现;

4、

构造函数,注解在类上

@AllArgsConstructor                会生成一个包含所有变量,同时如果变量使用了NotNull annotation , 会进行是否为空的校验, 
全部参数的构造函数的自动生成,该注解的作用域也是只有在实体类上,参数的顺序与属性定义的顺序一致。

@NoArgsConstructor               无参构造函数

@RequiredArgsConstructor     会生成一个包含常量(final),和标识了@NotNull的变量 的构造方法。

 

5、需要日志的地方,可以根据日志依赖,在类声明的上方追加 @Log4j、@Log4j2或 @Slf4j,然后直接在方法中直接使用log对象。

6、

@Builder : 注解在类上, 为类提供一个内部的 Builder

@SneakThrows :

@Synchronized : 注解在方法上, 为方法提供同步锁

 

7、Accessors翻译是存取器。通过该注解可以控制getter和setter方法的形式。

@Accessors(fluent = true)
使用fluent属性,getter和setter方法的方法名都是属性名,且setter方法返回当前对象

@Data
@Accessors(fluent = true)
class User {
    private Integer id;
    private String name;
    
    // 生成的getter和setter方法如下,方法体略
    public Integer id(){}
    public User id(Integer id){}
    public String name(){}
    public User name(String name){}
}
@Accessors(chain = true)
使用chain属性,setter方法返回当前对象

@Data
@Accessors(chain = true)
class User {
    private Integer id;
    private String name;
    
    // 生成的setter方法如下,方法体略
    public User setId(Integer id){}
    public User setName(String name){}
}
@Accessors(prefix = “f”)
使用prefix属性,getter和setter方法会忽视属性名的指定前缀(遵守驼峰命名)

@Data
@Accessors(prefix = "f")
class User {
    private Integer fId;
    private String fName;
    
    // 生成的getter和setter方法如下,方法体略
    public Integer id(){}
    public void id(Integer id){}
    public String name(){}
    public void name(String name){}
}

### 三级标题:LombokMaven 集成方式 要在 Maven 项目使用 Lombok,需要在 `pom.xml` 文件中添加 Lombok 的依赖项。以下是一个典型的配置示例: ```xml <dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.24</version> <scope>provided</scope> </dependency> </dependencies> ``` 此依赖声明会将 Lombok 引入项目,并确保其在编译和运行时可用。由于 Lombok 是通过注解处理器在编译阶段生成代码,因此通常将其作用域设置为 `provided`,表示它不会打包进最终的构建产物中[^1]。 ### 三级标题:Lombok 的基本使用方法 Lombok 提供了多种注解来简化 Java 类的编写,例如 `@Builder` 可用于自动生成构建器模式相关的代码。以下是一个使用 `@Builder` 注解的类示例: ```java package com.semlinker.lombok; import lombok.Builder; @Builder public class BuilderDemo { private final String firstName; private final String lastName; private final String email; } ``` 上述代码在编译后会自动生成一个包含所有字段的构造函数、静态构建方法以及链式调用风格的 setter 方法,从而避免手动编写冗余的样板代码。 ### 三级标题:Lombok 对开发环境的支持 为了使 IDE(如 IntelliJ IDEA 或 Eclipse)正确识别 Lombok 注解并提供相应的自动补全与编译支持,需要安装 Lombok 插件。例如,在 IntelliJ IDEA 中可以通过插件市场搜索 “Lombok” 并安装官方插件以启用完整的 Lombok 支持。 此外,如果项目使用 Spring Boot 或其他基于注解的框架,也可以结合 Lombok 来减少模板代码。例如,在控制器类中可以使用 `@Slf4j` 自动生成日志记录器实例: ```java package com.example.demo.abc.controller; import com.example.demo.abc.business.spec.HahaBusiness; import com.example.demo.abc.domain.param.FindAllHahaParam; import com.example.demo.abc.domain.vo.HahaVo; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; import java.util.List; @Api(tags = "Haha管理") @RestController @Slf4j public class HahaController { @Autowired HahaBusiness hahaBusiness; @ApiOperation(value = "查询Haha记录") @PostMapping(value = "/abc/hahas/list") public List<HahaVo> findAll(FindAllHahaParam param) { List<HahaVo> hahaVoList = hahaBusiness.findAll(param); return hahaVoList; } } ``` 该类中的 `@Slf4j` 注解会自动生成名为 `log` 的 SLF4J 日志记录器,无需手动创建日志对象[^3]。 ### 三级标题:Maven 配置优化建议 在使用 Maven 构建项目时,推荐配置镜像以加速依赖下载。可以在 `settings.xml` 文件中添加阿里云 Maven 镜像配置: ```xml <mirrors> <mirror> <id>aliyunmaven</id> <mirrorOf>*</mirrorOf> <name>阿里云公共仓库</name> <url>https://maven.aliyun.com/repository/public</url> </mirror> </mirrors> ``` 这样可以显著提高依赖解析速度,特别是在国内网络环境下[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值