Lombok如何快速構建JavaBean與日志輸出

快速構建JavaBean與日志輸出

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

以前的JavaBean是這樣的

現在的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);
        }
    }
}

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: