欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Lombok如何快速構(gòu)建JavaBean與日志輸出

 更新時間:2022年03月07日 11:39:39   作者:沖奶粉的奶爸  
這篇文章主要介紹了Lombok如何快速構(gòu)建JavaBean與日志輸出,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

快速構(gòu)建JavaBean與日志輸出

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

以前的JavaBean是這樣的

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

使用Lombok前的準(zhǔn)備操作

①添加maven依賴,或者到官網(wǎng)下載對應(yīng)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

操作指南:

構(gòu)造器,日志等注解必須標(biāo)注在類上,setter/getter等方法標(biāo)注在類上時,作用在所有成員變量上,當(dāng)標(biāo)注在成員變量上時,只有該變量起作用。

注解的具體作用:

@NoArgsConstructor //空參構(gòu)造器
@AllArgsConstructor //全參構(gòu)造器
@Data //set,get,toString等方法
@Accessors(chain=true)? //鏈?zhǔn)斤L(fēng)格訪問,new Dept().setName("cmj").setDeptno(1000L).setDb_source("db01");

那么問題來了,當(dāng)我們需要在getter方法中進(jìn)行操作時,如當(dāng)年齡字段為null時,我需要返回給我一個數(shù)字20,這我們該怎么辦呢?

其實(shí)lombok還是很給力的,當(dāng)注解和getter等方法有沖突時,該變量的注解將失去作用,其作用的將是我們自定義的方法。

@Slf4j

標(biāo)注在類上,相當(dāng)于

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: 自動幫我們調(diào)用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("查詢結(jié)果:"+result);
        if(result!=null){
            return new CommonResult(200,"查詢成功",result);
        } else {
            return new CommonResult(444,"沒有查到,ID:"+id,null);
        }
    }
}

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • SpringMVC中@controllerAdvice注解的詳細(xì)解釋

    SpringMVC中@controllerAdvice注解的詳細(xì)解釋

    剛接觸SpringMVC應(yīng)該很少會見到這個注解,其實(shí)它的作用非常大,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@controllerAdvice注解的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • MybatisX 快速開發(fā)插件過程詳解

    MybatisX 快速開發(fā)插件過程詳解

    MybatisX 是一款基于 IDEA 的快速開發(fā)插件,方便在使用mybatis以及mybatis-plus開始時簡化繁瑣的重復(fù)操作,提高開發(fā)速率。這篇文章主要介紹了MybatisX 快速開發(fā)插件,需要的朋友可以參考下
    2021-10-10
  • java中如何反射獲取一個類

    java中如何反射獲取一個類

    大家說說對java反射的理解,使用反射如何獲取一個類,下面小編給大家整理一些資料,關(guān)于java中如何反射獲取一個類,有需要的朋友可以參考下
    2015-08-08
  • java哈夫曼樹實(shí)例代碼

    java哈夫曼樹實(shí)例代碼

    這篇文章主要為大家介紹了java哈夫曼樹實(shí)例代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 將項(xiàng)目上傳到Maven中央倉庫(2023最新版)

    將項(xiàng)目上傳到Maven中央倉庫(2023最新版)

    本文主要介紹了將項(xiàng)目上傳到Maven中央倉庫(2023最新版),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • OAuth2生成token代碼備忘實(shí)現(xiàn)過程示例

    OAuth2生成token代碼備忘實(shí)現(xiàn)過程示例

    這篇文章主要為大家介紹了OAuth2生成token代碼備忘實(shí)現(xiàn)過程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 詳解SpringBoot中關(guān)于%2e的Trick

    詳解SpringBoot中關(guān)于%2e的Trick

    這篇文章主要介紹了SpringBoot中關(guān)于%2e的Trick,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • JAVA注解相關(guān)知識總結(jié)

    JAVA注解相關(guān)知識總結(jié)

    這篇文章主要介紹了JAVA注解相關(guān)知識,文中講解非常詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • 利用POI生成EXCEL文件的方法實(shí)例

    利用POI生成EXCEL文件的方法實(shí)例

    Apache POI 是用Java編寫的免費(fèi)開源的跨平臺的 Java API,Apache POI提供API給Java程式對Microsoft Office格式檔案讀和寫的功能,下面這篇文章主要給大家介紹了關(guān)于利用POI生成EXCEL文件的相關(guān)資料,需要的朋友可以參考下
    2018-07-07
  • java sleep()和wait()的區(qū)別點(diǎn)總結(jié)

    java sleep()和wait()的區(qū)別點(diǎn)總結(jié)

    在本篇文章里小編給大家整理了一篇關(guān)于java sleep()和wait()的區(qū)別的相關(guān)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-04-04

最新評論