Lombok如何快速構建JavaBean與日志輸出
快速構建JavaBean與日志輸出
我們在寫基類JavaBean時,當定義了成員變量后,我們不得不添加構造器,setter/getter方法以及toString方法,雖然eclipse等開發(fā)工具有一鍵生成策略,但是對我們來說仍覺得繁瑣,并且當我們在對該類進行添加或者刪除成員變量操作時,我們又得人為的去增添或刪除setter/getter方法,此等重復操作大大地刺激到了正處于開發(fā)崩潰邊緣的程序員,因此,lombok應運而生,幫我們解決了“懶”的問題。
以前的JavaBean是這樣的

現(xiàn)在的JavaBean是這樣的

使用Lombok前的準備操作
①添加maven依賴,或者到官網下載對應jar包 https://projectlombok.org/download
<dependency>?? ? ? ? ? ? ? <groupId>org.projectlombok</groupId>?? ? ? ? ? ? ? <artifactId>lombok</artifactId>?? ? ? ? ? ? ? <version>1.16.16</version>?? ? ? ? ? </dependency>?
②為eclipse等工具安裝好插件
<1>將lombok.jar移到eclipse的安裝目錄

<2>在eclipse.in文件最后加入下面一行-javaagent:D:\install\jee-oxygen\eclipse\lombok.jar
<3>重啟eclipse
操作指南:
構造器,日志等注解必須標注在類上,setter/getter等方法標注在類上時,作用在所有成員變量上,當標注在成員變量上時,只有該變量起作用。
注解的具體作用:
@NoArgsConstructor //空參構造器
@AllArgsConstructor //全參構造器
@Data //set,get,toString等方法
@Accessors(chain=true)? //鏈式風格訪問,new Dept().setName("cmj").setDeptno(1000L).setDb_source("db01");那么問題來了,當我們需要在getter方法中進行操作時,如當年齡字段為null時,我需要返回給我一個數字20,這我們該怎么辦呢?
其實lombok還是很給力的,當注解和getter等方法有沖突時,該變量的注解將失去作用,其作用的將是我們自定義的方法。

@Slf4j
標注在類上,相當于
private? final Logger logger = LoggerFactory.getLogger(XXX.class);
@NonNull: 可以幫助我們避免空指針。
使用lombok:
import lombok.NonNull;
public class NonNullExample extends Something {
private String name;
public NonNullExample(@NonNull Person person) {
super("Hello");
this.name = person.getName();
}
}不使用lombok:
public class NonNullExample extends Something {
private String name;
public NonNullExample(@NonNull Person person) {
super("Hello");
if (person == null) {
throw new NullPointerException("person");
}
this.name = person.getName();
}
}@Cleanup: 自動幫我們調用close()方法。
使用@Cleanup:
import lombok.Cleanup;
import java.io.*;
public class CleanupExample {
? ? public static void main(String[] args) throws IOException {
? ? ? ? @Cleanup InputStream in = new FileInputStream(args[0]);
? ? ? ? @Cleanup OutputStream out = new FileOutputStream(args[1]);
? ? ? ? byte[] b = new byte[10000];
? ? ? ? while (true) {
? ? ? ? ? ? int r = in.read(b);
? ? ? ? ? ? if (r == -1) break;
? ? ? ? ? ? out.write(b, 0, r);
? ? ? ? }
? ? }
}不用@Cleanup:
import java.io.*;
? ? public class CleanupExample {
? ? ? ? public static void main(String[] args) throws IOException {
? ? ? ? ? ? InputStream in = new FileInputStream(args[0]);
? ? ? ? ? ? try {
? ? ? ? ? ? ? ? OutputStream out = new FileOutputStream(args[1]);
? ? ? ? ? ? ? ? try {
? ? ? ? ? ? ? ? ? ? byte[] b = new byte[10000];
? ? ? ? ? ? ? ? ? ? while (true) {
? ? ? ? ? ? ? ? ? ? int r = in.read(b);
? ? ? ? ? ? ? ? ? ? if (r == -1) break;
? ? ? ? ? ? ? ? ? ? out.write(b, 0, r);
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? } finally {
? ? ? ? ? ? ? ? ? ? if (out != null) {
? ? ? ? ? ? ? ? ? ? ? ? out.close();
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? } finally {
? ? ? ? ? ? ? ? if (in != null) {
? ? ? ? ? ? ? ? in.close();
? ? ? ? ? ? }
? ? ? ? }
? ? }
}IDEA使用lombok輸出日志
安裝lombok插件

pom.xml加入依賴
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
<version>1.16.18</version>
</dependency>
使用@Slf4j注解
使用log對象的info()方法
@RestController
@Slf4j
public class PaymentController {
@Autowired
private PaymentService paymentService;
@GetMapping(value = "/payment/get/{id}")
public CommonResult getById(@PathVariable("id") long id){
Payment result = paymentService.getPaymentById(id);
log.info("查詢結果:"+result);
if(result!=null){
return new CommonResult(200,"查詢成功",result);
} else {
return new CommonResult(444,"沒有查到,ID:"+id,null);
}
}
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot配置logback.xml 多環(huán)境的操作步驟
最近在研究springboot的日志,所以記錄一下,做一下總結,今天重點給大家介紹SpringBoot配置logback.xml 多環(huán)境的操作步驟,要實現(xiàn)多環(huán)境的配置,主要是依賴于springboot的application.yml文件去實現(xiàn),感興趣的朋友跟隨小編一起看看吧2021-05-05
SpringBoot集成JmsTemplate(隊列模式和主題模式)及xml和JavaConfig配置詳解
這篇文章主要介紹了SpringBoot集成JmsTemplate(隊列模式和主題模式)及xml和JavaConfig配置詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08
使用Vue+Spring Boot實現(xiàn)Excel上傳功能
這篇文章主要介紹了使用Vue+Spring Boot實現(xiàn)Excel上傳,需要的朋友可以參考下2018-11-11
使用SpringMVC在redirect重定向的時候攜帶參數的問題
這篇文章主要介紹了使用SpringMVC在redirect重定向的時候攜帶參數的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
springboot2.6.4集成swagger3.0遇到的坑及解決方法
這篇文章主要介紹了springboot2.6.4如何集成swagger3.0,在集成的過程中遇到很多問題,本文給大家分享四種問題及相應的解決方案,需要的朋友可以參考下2022-03-03

