目录
一.Lombok
1.Lombok 介绍
1.1Lombok 作用
1.2SpringBoot 和 IDEA 官方支持
2.Lombok 常用注解
3.Lombok 应用实例
3.1在 pom.xml 引入 lombok
3.2. 修改 Furn.java
3.3在 idea 安装 lombok 插件
一.Lombok
1.Lombok 介绍
1.1Lombok 作用
1.
简化
JavaBean
开发
,
可以使用
Lombok
的注解让代码更加简洁
2. Java
项目中,
很多没有技术含量又必须存在的代码
:
POJO
的
getter/setter/toString
;异常处理;I/O
流的关闭操作等等,这些代码既没有技术含量,又影响着代码的美观,
Lombok 应运而生
1.2SpringBoot 和 IDEA 官方支持
1. IDEA 2020
已经内置了
Lombok
插件
2. SpringBoot 2.1.x
之后的版本也在
Starter
中内置了
Lombok
依赖
2.Lombok 常用注解
3.Lombok 应用实例
3.1在 pom.xml 引入 lombok
<!-- 引 入 lombok, 版 本 在 spring-boot-dependencies-2.5.3.pom 指 定 了 , 把 光 标 放 在
lombok ctrl+b 可以看到-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
-----------------------------------------看对应的版本---------------------------------------------
3.2. 修改 Furn.java
使用 Lombok 注解简化代码, 提示:可以通过 idea 自带的反编译功能, 看 Furn.class 的源码, 就可以看到生成的完整代码
@Component
@ConfigurationProperties(prefix = "furn01")
//@ToString //在编译时,生成toString, 默认情况下,会生成一个无参构造器
/**
* 说明:
* 1. Equivalent to {@code @Getter @Setter @RequiredArgsConstructor @ToString @EqualsAndHashCode}
* 2. @Data 注解等价使用了 如下注解 @Getter @Setter @RequiredArgsConstructor @ToString @EqualsAndHashCode
* 3. @RequiredArgsConstructor : 单独的说一下:
*/
//@Data
//说明: @NoArgsConstructor 在编译时,会生成无参构造器, 前面老师说过,默认情况下,会生成一个无参构造器
//说明:当我们有其它构造器生成时,如果你希望仍然有无参构造器就需要使用@NoArgsConstructor指定一下
// ,否则就会覆盖无参构造器,从而代码错误
@NoArgsConstructor
//说明:@AllArgsConstructor 在编译时,会生成全参构造器
@AllArgsConstructor
@ToString
@Setter
@Getter//时json获取数据的主要方法get方法,因为json底层使用的是getId等等方法
public class Furn {
private Integer id;
private String name;
private Double price;
}
3.3在 idea 安装 lombok 插件
不装插件也可以用基本的注解,比如 @Data @Getter 等, 但 是不能使用其扩展功能, 比如日志输出..., 所以我们还是安装一下,也比较简单
5. 演 示 使 用 Lombok 支 持 日 志 输 出 ( 建 议 使 用 slf4j),
import com.hong.springboot.bean.Furn;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.annotation.Resource;
/**
* @author 海绵hong
* @version 1.0
*/
@Slf4j
@Controller
public class HiController {
//需求website 属性值从application.properties 的k-v
@Value("${my.website}")
private String website;
//装配到HiController
@Resource
private Furn furn;
//返回hi,springboot
@RequestMapping("/hi")
@ResponseBody
public String hi() {
System.out.println("website-" + website);
return "hi~, SpringBoot";
}
@RequestMapping("/furn")
@ResponseBody
public Furn furn() {
//System.out.println("furn--" + furn);
//使用slf4j日志输出
//普通方式
log.info("furn-" + furn);
//占位符方式输出
log.info("furn={} myfurn={}", furn, furn);
return furn;
}
}