偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

我承認,要放棄使用Lombok了!

開發(fā) 后端 開發(fā)工具
我承認,Lombok是一個很不錯的 Java 庫,它可以讓你在少寫代碼的同時耍???,簡單的幾個注解,就可以干掉一大片模板代碼。

 我承認,Lombok是一個很不錯的 Java 庫,它可以讓你在少寫代碼的同時耍???,簡單的幾個注解,就可以干掉一大片模板代碼。

[[332588]]

 

圖片來自 Pexels

但是,所有的源代碼很多時候是用來閱讀的,只有很少的時間是用來執(zhí)行的(你可以細品這句話)。

一年以前,我和大多數(shù)人都認為 Lombok 的出現(xiàn)會讓 Java 的編碼體驗會更好,并極力的在我的團隊中推薦使用 Lombok。

一年以后,我開始對此產(chǎn)生顧慮,尤其是在我準備為開源的博客系統(tǒng) Una-Boot 升級 Java 版本時,我才意識到 Lombok 自己掉入了一個戲法陷阱。

在我進一步分析其源代碼并理解相關(guān)注解的工作原理后,發(fā)現(xiàn)我并不需要使用一個非標準的第三方庫將 Java 轉(zhuǎn)換為一個精巧而酷炫的語言。

引入 Lombok 讓我的項目一時爽,但一時爽的代價是隨著項目推進,技術(shù)債務(wù)開始累積。

接下來,我將用幾個大家耳熟能詳?shù)膱鼍?,重演自己是如何掉?Lombok 的戲法陷阱。

愛的開始,恨的起源

面對 Lombok 提供的諸多“神走位”,你并不會介意在 IDE 上新增一個插件。對于 IntelliJ IDEA 玩家而言,只需搜索“Lombok Plugin”便可找到這款神器并安裝上它。愛上 Lombok 從安裝 Lombok 插件開始,恨也從此萌芽。

沒使用 Lombok 之前,我們的源代碼看起來是這一的:

  1. public class MyObject{ 
  2.     private Long id; 
  3.     private String name
  4.     private int age; 
  5.     private int gender; 
  6.  
  7.     public Long getId(){ 
  8.         return id; 
  9.     } 
  10.     public void setId(Long id){ 
  11.         this.id = id; 
  12.     } 
  13.     public String getName(){ 
  14.         return name
  15.     } 
  16.     public void setName(String name){ 
  17.         this.name = name
  18.     } 
  19.     public int getAge(){ 
  20.         return age; 
  21.     } 
  22.     public void setAge(int age){ 
  23.         this.age = age; 
  24.     } 
  25.     public int getGender(){ 
  26.         return gender; 
  27.     } 
  28.     public void setGender(int gender){ 
  29.         this.gender = gender; 
  30.     } 
  31.  
  32.     @Override 
  33.     public boolean equals(Object o){ 
  34.         if(this == o){ 
  35.             return true
  36.         } 
  37.         if(o == null || getClass() != o.getClass()){ 
  38.             return false
  39.         } 
  40.         MyObject obj = (MyObject) o; 
  41.         return age = obj.age && 
  42.             gender = obj.gender && 
  43.             Objects.equals(id,obj.id) && 
  44.             Objects.queals(name,obj.name); 
  45.     } 
  46.  
  47.     @Override 
  48.     public int hashCode(){ 
  49.         return Objects.hash(id,name,age,gender); 
  50.     } 
  51.  
  52.     @Override 
  53.     public String toString(){ 
  54.         return "MyObject{"
  55.             "id="+id+ 
  56.             "name="+name
  57.             "age="+age+ 
  58.             "gender="+gander+ 
  59.             "}"
  60.     } 

每個 JavaBean 都會充斥著如上述 getter,setter,equals,hashCode 和 toString 的模板代碼,這看起來像一個偏胖的人(不得不承認 Java 是一個有缺陷的編程語言)。

當(dāng)我們安裝好 Lombok 插件后,IDE 便可以識別其酷炫的注解,使用 Lombok 的 @Getter 和 @Setter 注解后,代碼會像下面這樣看起來很苗條:

  1. @Getter 
  2. @Setter 
  3. public class MyObject{ 
  4.     private Long id; 
  5.     private String name
  6.     private int age; 
  7.     private int gender; 
  8.  
  9.     @Override 
  10.     public boolean equals(Object o){ 
  11.         if(this == o){ 
  12.             return true
  13.         } 
  14.         if(o == null || getClass() != o.getClass()){ 
  15.             return false
  16.         } 
  17.         MyObject obj = (MyObject) o; 
  18.         return age = obj.age && 
  19.             gender = obj.gender && 
  20.             Objects.equals(id,obj.id) && 
  21.             Objects.queals(name,obj.name); 
  22.     } 
  23.  
  24.     @Override 
  25.     public int hashCode(){ 
  26.         return Objects.hash(id,name,age,gender); 
  27.     } 
  28.  
  29.     @Override 
  30.     public String toString(){ 
  31.         return "MyObject{"
  32.             "id="+id+ 
  33.             "name="+name
  34.             "age="+age+ 
  35.             "gender="+gander+ 
  36.             "}"
  37.     } 

現(xiàn)在的代碼是否看起來爽多了?但這還不是最爽的時候。既然其他方法都替換掉了,那把 toString 方法也一起拿掉吧.如你所愿,可以使用 @ToString 注解去掉對于的方法:

  1. @Getter 
  2. @Setter 
  3. @EqualsAndHashCode 
  4. public class MyObject{ 
  5.     private Long id; 
  6.     private String name
  7.     private int age; 
  8.     private int gender; 
  9.  
  10.     @Override 
  11.     public String toString(){ 
  12.         return "MyObject{"
  13.             "id="+id+ 
  14.             "name="+name
  15.             "age="+age+ 
  16.             "gender="+gander+ 
  17.             "}"
  18.     } 

經(jīng)過 Lombok 的戲法之后,相比一開始的代碼,看起來是不是很酷炫,很苗條,很性感?你以為到此為止了?

遠不止于此,你會發(fā)現(xiàn)類名上一大坨注解看起來好別扭,Lombok 提供了一個組合注解 @Data,可以替換掉類名頭上那坨像翔一樣的東西:

  1. @Data 
  2. public class MyObject{ 
  3.     private Long id; 
  4.     private String name
  5.     private int age; 
  6.     private int gender; 

現(xiàn)在,Lombok 是否讓你的對象成為了你心目中完美的樣子?魔鬼的“身材”,酷炫精煉。

Lombok 還有其他一些注解,如 @Slf4j,@NoArgsConstructor,@AllArgsConstructor 等等,介紹 Lombok 用法不是本文重點。

以上代碼行數(shù)的變化過程,也許是無數(shù)程序員愛上 Lombok 的主要原因吧,這就像一個肥胖的人逐漸變成一個身材苗條的人。

同時也讓你看到了一個現(xiàn)象:你以為程序員很懶嗎?其他有些時候他們比你想象中的還要懶。在爽的同時,也為代碼種下了禍根。

扭曲的審美,愛的隱患

扭曲的審美,導(dǎo)致了被審視的對象處于亞健康狀態(tài)。使用 Lombok 插件之后,我們的代碼也處于“亞健康”狀態(tài)。

還是回歸一開始的那句話:所有的源代碼很多時候是用來閱讀的,只有很少的時間是用來執(zhí)行的。

本質(zhì)上講,我們都追求減少程序中的樣板代碼以使其代碼更精煉簡潔,從而提高代碼的可讀性和可維護性。

但 Lombok 并沒有達到我們所追求的這一愿景,它僅僅是利用 Java 語言在編譯時的空檔期,使用一種很取巧的方式,將我們所需要的方法注入(寫入)到當(dāng)前的類中,這種過程很像在 hack 我們的代碼,只是一種看起來酷炫的把戲。

這種把戲并不智能和安全,反而會破壞 Java 代碼現(xiàn)有的特性以及代碼的可讀性。

下面,結(jié)合我自己使用 Lombok 之后的感受,談?wù)?Lombok 帶來的幾大痛點。

JDK 版本問題

當(dāng)我想要將現(xiàn)有項目的 JDK 從 Java 8 升級到 Java 11 時,我發(fā)現(xiàn) Lombok 不能正常工作了。

于是我不得不將所有的 Lombok 注解從項目源代碼中清除,并使用 IDE 自帶的功能生成 getter/setter,equals,hashCode,toString 以及構(gòu)造器等方法。

你也可以使用 Delombok 工具完成這一過程,但這終究會消耗你很多的時間。

脅迫使用

當(dāng)你的源代碼中使用了 Lombok,恰好你的代碼又被其他的人所使用,那么依賴你代碼的人,也必須安裝 Lombok 插件(不管他們喜不喜歡),同時還要花費時間去了解 Lombok 注解的使用情況,如果不那么做,代碼將無法正常運行。使用過 Lombok 之后,我發(fā)現(xiàn)這是一種很流氓的行為。

可讀性差

Lombok 隱藏了 JavaBean 封裝的細節(jié),如果你使用 @AllArgsConstructor 注解,它將提供一個巨型構(gòu)造器,讓外界有機會在初始化對象時修改類中所有的屬性。

首先,這是極其不安全的,因為類中某系屬性我們是不希望被修改的;另外,如果某個類中有幾十個屬性存在,就會有一個包含幾十個參數(shù)的構(gòu)造器被 Lombo k注入到類中,這是不理智的行為。

其次,構(gòu)造器參數(shù)的順序完全由 Lombok 所控制,我們并不能操控,只有當(dāng)你需要調(diào)試時才發(fā)現(xiàn)有一個奇怪的“小強”在等著你。

最后,在運行代碼之前,所有 JavaBean 中的方法你只能想象他們長什么樣子,你并不能看見。

代碼耦合度增加

當(dāng)你使用 Lombok 來編寫某一個模塊的代碼后,其余依賴此模塊的其他代碼都需要引入 Lombok 依賴,同時還需要在 IDE 中安裝 Lombok 的插件。

雖然 Lombok 的依賴包并不大,但就因為其中一個地方使用了 Lombok,其余所有的依賴方都要強制加入 Lombok 的 Jar 包,這是一種入侵式的耦合,如果再遇上 JDK 版本問題,這將是一場災(zāi)難。

得不償失

使用 Lombok,一時覺得很爽,但它卻污染了你的代碼,破壞了 Java 代碼的完整性,可讀性和安全性,同時還增加的團隊的技術(shù)債務(wù),這是一種弊大于利,得不償失的操作。

 

 

如果你確實想讓自己的代碼更加精煉,同時又兼顧可讀性和編碼效率,不妨使用主流的 Scala 或 Kotlin 這一基于 JVM 的語言。

總結(jié)

Lombok 本身是一個優(yōu)秀的 Java 代碼庫,它采用了一種取巧的語法糖,簡化了 Java 的編碼,為 Java 代碼的精簡提供了一種方式,但在使用此代碼庫時,需要了解到 Lombok 并非一個標準的 Java 庫。

使用 Lombok,會增加團隊的技術(shù)債務(wù),降低代碼的可讀性,增大代碼的耦合度和調(diào)式難度。

雖然在一定程度上 Lombok 減少了樣板代碼的書寫,但也帶來了一些未知的風(fēng)險。

如果你正在參與一個團隊項目(或大型項目),考慮到后續(xù)的升級與擴展,是否使用 Lombok,請與你的團隊多溝通和三思。

作者:ramostear

編輯:陶家龍

出處:https://www.toutiao.com/a6820517160964588044/

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2020-03-03 15:31:47

ReactVue前端

2023-07-23 17:19:34

人工智能系統(tǒng)

2015-07-17 09:59:18

2018-12-21 11:26:49

MySQLMongoDB數(shù)據(jù)庫

2020-03-25 18:15:42

JavaclassLombok

2023-01-09 07:50:29

開源開發(fā)者項目

2018-05-04 10:45:58

戴爾

2013-01-31 18:52:58

CiscoACEF5

2023-07-07 09:08:21

2020-05-06 08:21:37

程序員年薪能力

2023-05-05 00:08:37

AxiosAlova開發(fā)

2023-01-19 00:13:28

代碼技術(shù)計劃

2023-04-20 17:51:41

馬斯克微軟

2022-12-19 07:38:02

Rust項目代碼

2020-06-19 08:01:48

Kotlin 協(xié)程編程

2017-07-31 19:13:58

白熊視頻技術(shù)創(chuàng)業(yè)在路上程序員

2024-07-02 17:43:26

2020-09-27 14:13:50

Spring BootJava框架

2021-03-01 09:16:10

程序員系統(tǒng)模式

2015-03-24 11:10:11

MongoDBPostgreSQLMySQL
點贊
收藏

51CTO技術(shù)棧公眾號