Lombok如何快速構(gòu)建JavaBean與日志輸出
快速構(gòu)建JavaBean與日志輸出
我們?cè)趯?xiě)基類JavaBean時(shí),當(dāng)定義了成員變量后,我們不得不添加構(gòu)造器,setter/getter方法以及toString方法,雖然eclipse等開(kāi)發(fā)工具有一鍵生成策略,但是對(duì)我們來(lái)說(shuō)仍覺(jué)得繁瑣,并且當(dāng)我們?cè)趯?duì)該類進(jìn)行添加或者刪除成員變量操作時(shí),我們又得人為的去增添或刪除setter/getter方法,此等重復(fù)操作大大地刺激到了正處于開(kāi)發(fā)崩潰邊緣的程序員,因此,lombok應(yīng)運(yùn)而生,幫我們解決了“懶”的問(wèn)題。
以前的JavaBean是這樣的
現(xiàn)在的JavaBean是這樣的
使用Lombok前的準(zhǔn)備操作
①添加maven依賴,或者到官網(wǎng)下載對(duì)應(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)注在類上時(shí),作用在所有成員變量上,當(dāng)標(biāo)注在成員變量上時(shí),只有該變量起作用。
注解的具體作用:
@NoArgsConstructor //空參構(gòu)造器 @AllArgsConstructor //全參構(gòu)造器 @Data //set,get,toString等方法 @Accessors(chain=true)? //鏈?zhǔn)斤L(fēng)格訪問(wèn),new Dept().setName("cmj").setDeptno(1000L).setDb_source("db01");
那么問(wèn)題來(lái)了,當(dāng)我們需要在getter方法中進(jìn)行操作時(shí),如當(dāng)年齡字段為null時(shí),我需要返回給我一個(gè)數(shù)字20,這我們?cè)撛趺崔k呢?
其實(shí)lombok還是很給力的,當(dāng)注解和getter等方法有沖突時(shí),該變量的注解將失去作用,其作用的將是我們自定義的方法。
@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: 自動(dòng)幫我們調(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對(duì)象的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,"沒(méi)有查到,ID:"+id,null); } } }
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringMVC中@controllerAdvice注解的詳細(xì)解釋
剛接觸SpringMVC應(yīng)該很少會(huì)見(jiàn)到這個(gè)注解,其實(shí)它的作用非常大,下面這篇文章主要給大家介紹了關(guān)于SpringMVC中@controllerAdvice注解的相關(guān)資料,需要的朋友可以參考下2022-02-02MybatisX 快速開(kāi)發(fā)插件過(guò)程詳解
MybatisX 是一款基于 IDEA 的快速開(kāi)發(fā)插件,方便在使用mybatis以及mybatis-plus開(kāi)始時(shí)簡(jiǎn)化繁瑣的重復(fù)操作,提高開(kāi)發(fā)速率。這篇文章主要介紹了MybatisX 快速開(kāi)發(fā)插件,需要的朋友可以參考下2021-10-10將項(xiàng)目上傳到Maven中央倉(cāng)庫(kù)(2023最新版)
本文主要介紹了將項(xiàng)目上傳到Maven中央倉(cāng)庫(kù)(2023最新版),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05OAuth2生成token代碼備忘實(shí)現(xiàn)過(guò)程示例
這篇文章主要為大家介紹了OAuth2生成token代碼備忘實(shí)現(xiàn)過(guò)程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08詳解SpringBoot中關(guān)于%2e的Trick
這篇文章主要介紹了SpringBoot中關(guān)于%2e的Trick,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04java sleep()和wait()的區(qū)別點(diǎn)總結(jié)
在本篇文章里小編給大家整理了一篇關(guān)于java sleep()和wait()的區(qū)別的相關(guān)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2021-04-04