您好,登錄后才能下訂單哦!
小編給大家分享一下Lombok怎么快速構建JavaBean與日志輸出,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
我們在寫基類JavaBean時,當定義了成員變量后,我們不得不添加構造器,setter/getter方法以及toString方法,雖然eclipse等開發工具有一鍵生成策略,但是對我們來說仍覺得繁瑣,并且當我們在對該類進行添加或者刪除成員變量操作時,我們又得人為的去增添或刪除setter/getter方法,此等重復操作大大地刺激到了正處于開發崩潰邊緣的程序員,因此,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等方法有沖突時,該變量的注解將失去作用,其作用的將是我們自定義的方法。
標注在類上,相當于
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(); } } } }
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> <version>1.16.18</version> </dependency>
使用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); } } }
以上是“Lombok怎么快速構建JavaBean與日志輸出”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。