国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

重演自己如何掉入Lombok的戲法陷阱

Android編程精選 ? 來源:ramostear ? 作者:樹下魅狐 ? 2021-10-28 11:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

https://www.ramostear.com/blog/2020/04/28/uk1860p8.html 如果您正在閱讀此文,想必您對Project Lombok已經有了一段時間的了解。您是否正準備擁抱Lombok?還是正準備將如此酷炫的項目推薦給你的團隊?如果您準備那么做,不妨聽聽我在使用Lombok一年后的一些感受。我承認,Lombok是一個很不錯的Java庫,它可以讓你在少寫代碼的同時耍耍酷,簡單的幾個注解,就可以干掉一大片模板代碼。但是,所有的源代碼很多時候是用來閱讀的,只有很少的時間是用來執行的(你可以細品這句話)。 一年以前,我和大多數人都認為Lombok的出現會讓Java的編碼體驗會更好,并極力的在我的團隊中推薦使用Lombok。一年以后,我開始對此產生顧慮,尤其是在我準備為開源的博客系統Una-Boot升級Java版本時,我才意識到Lombok自己掉入了一個戲法陷阱。在我進一步分析其源代碼并理解相關注解的工作原理后,發現我并不需要使用一個非標準的第三方庫將Java轉換為一個精巧而酷炫的語言。引入Lombok讓我的項目一時爽,但一時爽的代價是隨著項目推進,技術債務開始累積。接下來,我將用幾個大家耳熟能詳的場景,重演自己是如何掉入Lombok的戲法陷阱。

愛的開始,恨的起源

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

	

publicclassMyObject{ privateLongid; privateStringname; privateintage; privateintgender; publicLonggetId(){ returnid; } publicvoidsetId(Longid){ this.id=id; } publicStringgetName(){ returnname; } publicvoidsetName(Stringname){ this.name=name; } publicintgetAge(){ returnage; } publicvoidsetAge(intage){ this.age=age; } publicintgetGender(){ returngender; } publicvoidsetGender(intgender){ this.gender=gender; } @Override publicbooleanequals(Objecto){ if(this==o){ returntrue; } if(o==null||getClass()!=o.getClass()){ returnfalse; } MyObjectobj=(MyObject)o; returnage=obj.age&& gender=obj.gender&& Objects.equals(id,obj.id)&& Objects.queals(name,obj.name); } @Override publicinthashCode(){ returnObjects.hash(id,name,age,gender); } @Override publicStringtoString(){ return"MyObject{"+ "id="+id+ "name="+name+ "age="+age+ "gender="+gander+ "}"; } }

每個JavaBean都會充斥著如上述getter,setter,equals,hashCode和toString的模板代碼,這看起來像一個偏胖的人(不得不承認Java是一個有缺陷的編程語言)。當我們安裝好Lombok插件后,IDE便可以識別其酷炫的注解,使用Lombok的@Getter@Setter注解后,代碼會像下面這樣看起來很苗條:

	

@Getter @Setter publicclassMyObject{ privateLongid; privateStringname; privateintage; privateintgender; @Override publicbooleanequals(Objecto){ if(this==o){ returntrue; } if(o==null||getClass()!=o.getClass()){ returnfalse; } MyObjectobj=(MyObject)o; returnage=obj.age&& gender=obj.gender&& Objects.equals(id,obj.id)&& Objects.queals(name,obj.name); } @Override publicinthashCode(){ returnObjects.hash(id,name,age,gender); } @Override publicStringtoString(){ return"MyObject{"+ "id="+id+ "name="+name+ "age="+age+ "gender="+gander+ "}"; } }

你以為Lombok就這點能耐?它還能讓你代碼的“身材”更苗條,更魔鬼。上面的代碼仍然還有改進的空間,我們可以用@EqualsAndHashCod注解替換到equals和hashCode方法:

	

@Getter @Setter @EqualsAndHashCode publicclassMyObject{ privateLongid; privateStringname; privateintage; privateintgender; @Override publicStringtoString(){ return"MyObject{"+ "id="+id+ "name="+name+ "age="+age+ "gender="+gander+ "}"; } }

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

	

@Getter @Setter @EqualsAndHashCode @ToString publicclassMyObject{ privateLongid; privateStringname; privateintage; privateintgender; }

經過Lombok的戲法之后,相比一開始的代碼,看起來是不是很酷炫,很苗條,很性感?你以為到此為止了?遠不止于此。你會發現類名上一大坨注解看起來好別扭,Lombok提供了一個組合注解@Data,可以替換掉類名頭上那坨像翔一樣的東西:

	

@Data publicclassMyObject{ privateLongid; privateStringname; privateintage; privateintgender; }

現在,Lombok是否讓你的對象成為了你心目中完美的樣子?魔鬼的“身材”,酷炫精煉。Lombok還有其他一些注解,如@Slf4j@NoArgsConstructor@AllArgsConstructor等等,介紹Lombok用法不是本文重點。 以上代碼行數的變化過程,也許是無數程序員愛上Lombok的主要原因吧,這就像一個肥胖的人逐漸變成一個身材苗條的人。同時也讓你看到了一個現象:你以為程序員很懶嗎?其他有些時候他們比你想象中的還要懶。在爽的同時,也為代碼種下了禍根

扭曲的審美,愛的隱患

扭曲的審美,導致了被審視的對象出于亞健康狀態。使用Lombok插件之后,我們的代碼也處于“亞健康”狀態。還是回歸一開始的那句話:所有的源代碼很多時候是用來閱讀的,只有很少的時間是用來執行的。 本質上講,我們都追求減少程序中的樣板代碼以使其代碼更精煉簡潔,從而提高代碼的可讀性和可維護性。但Lombok并沒有達到我們所追求的這一愿景,它僅僅是利用Java語言在編譯時的空檔期,使用一種很取巧的方式,將我們所需要的方法注入(寫入)到當前的類中,這種過程很像在hack我們的代碼,只是一種看起來酷炫的把戲。這種把戲并不智能和安全,反而會破壞Java代碼現有的特性以及代碼的可讀性。下面,結合我自己使用Lombok之后的感受,談談Lombok帶來的幾大痛點。

1. JDK版本問題

當我想要將現有項目的JDK從Java 8升級到Java 11時,我發現Lombok不能正常工作了。于是我不得不將所有的Lombok注解從項目源代碼中清除,并使用IDE自帶的功能生成getter/setter,equals,hashCode,toString以及構造器等方法,你也可以使用Delombok工具完成這一過程。但這終究會消耗你很多的時間。

2. 脅迫使用

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

3. 可讀性差

Lombok隱藏了JavaBean封裝的細節,如果你使用@AllArgsConstructor注解,它將提供一個巨型構造器,讓外界有機會在初始化對象時修改類中所有的屬性。首先,這是極其不安全的,因為類中某系屬性我們是不希望被修改的;另外,如果某個類中有幾十個屬性存在,就會有一個包含幾十個參數的構造器被Lombok注入到類中,這是不理智的行為;其次,構造器參數的順序完全由Lombok所控制,我們并不能操控,只有當你需要調試時才發現有一個奇怪的“小強”在等著你;最后,在運行代碼之前,所有JavaBean中的方法你只能想象他們長什么樣子,你并不能看見。

4. 代碼耦合度增加

當你使用Lombok來編寫某一個模塊的代碼后,其余依賴此模塊的其他代碼都需要引入Lombok依賴,同時還需要在IDE中安裝Lombok的插件。雖然Lombok的依賴包并不大,但就因為其中一個地方使用了Lombok,其余所有的依賴方都要強制加入Lombok的Jar包,這是一種入侵式的耦合,如果再遇上JDK版本問題,這將是一場災難。

5. 得不償失

使用Lombok,一時覺得很爽,但它卻污染了你的代碼,破壞了Java代碼的完整性,可讀性和安全性,同時還增加的團隊的技術債務,這是一種弊大于利,得不償失的操作。如果你確實想讓自己的代碼更加精煉,同時又兼顧可讀性和編碼效率,不妨使用主流的Scala或Kotlin這一基于JVM的語言。

總結

Lombok本身是一個優秀的Java代碼庫,它采用了一種取巧的語法糖,簡化了Java的編碼,為Java代碼的精簡提供了一種方式,但在使用此代碼庫時,需要了解到Lombok并非一個標準的Java庫。使用Lombok,會增加團隊的技術債務,降低代碼的可讀性,增大代碼的耦合度和調式難度。雖然在一定程度上Lombok減少了樣板代碼的書寫,但也帶來了一些未知的風險。如果你正在參與一個團隊項目(或大型項目),考慮到后續的升級與擴展,是否使用Lombok,請與你的團隊多溝通和三思。
責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • JAVA
    +關注

    關注

    20

    文章

    3001

    瀏覽量

    116428
  • 代碼
    +關注

    關注

    30

    文章

    4968

    瀏覽量

    73960

原文標題:Lombok!代碼簡潔神器還是代碼“亞健康”元兇?

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    MCU選型的10大隱形陷阱

    Youtube上發布視頻,結合其行業閱歷,深度剖析了工程師在MCU芯片選型時最易踩中的十大隱性陷阱。 圖/Youtube截圖 《半導體器件應用網》對John Teel的觀點進行了梳理整理,希望能幫助工程師與工程師團隊避開MCU芯片選型中的隱形陷阱。 一、產品開發規劃期:M
    的頭像 發表于 02-27 09:24 ?99次閱讀
    MCU選型的10大隱形<b class='flag-5'>陷阱</b>

    FPGA DSP模塊使用中的十大關鍵陷阱

    FPGA 芯片中DSP(數字信號處理)硬核是高性能計算的核心資源,但使用不當會引入隱蔽性極強的“坑”。這些坑不僅影響性能和精度,甚至會導致功能錯誤。以下是總結了十大關鍵陷阱及其解決方案,分為 功能正確性、性能優化、系統集成 三個層面。
    的頭像 發表于 01-13 15:18 ?360次閱讀

    單片機可靠性差的解決辦法

    1、軟件陷阱是什么? 軟件陷阱是一種用于捕獲并處理單片機程序“跑飛”現象的技術,當程序執行過程中因干擾而偏離正常軌道時,軟件陷阱可及時發現并將程序拉回正常執行路徑。 2、軟件陷阱
    發表于 11-25 06:10

    玩轉VBAT,電源設計常見陷阱99%都能輕松避開!

    電源設計中的VBAT如同一把鑰匙,掌握它就能打開成功的大門。本文將教您如何玩轉VBAT,從而在電源設計中輕松避開高達99%的常見陷阱,確保您的設計既高效又可靠。 在物聯網開發中,穩定的VBAT供電
    的頭像 發表于 11-14 15:58 ?842次閱讀
    玩轉VBAT,電源設計常見<b class='flag-5'>陷阱</b>99%都能輕松避開!

    揭秘VBAT:電源設計陷阱的全方位規避策略

    VBAT在電源設計中扮演著舉足輕重的角色,但其背后的奧秘往往被忽視,導致設計過程中陷阱頻現。本文將為您揭秘VBAT的核心知識,并提供全方位的規避策略,助您有效避開電源設計中絕大多數常見陷阱。 在物
    的頭像 發表于 11-14 15:48 ?495次閱讀
    揭秘VBAT:電源設計<b class='flag-5'>陷阱</b>的全方位規避策略

    皮線光纜選購指南:避開3大陷阱,選對“光速通道”

    面對市場上琳瑯滿目的皮線光纜,如何避免“低價陷阱”或“性能過剩”?本文揭秘選購中的關鍵考量。 陷阱1:混淆光纖類型 G.652D光纖:成本低,但彎曲損耗大,適合長距離傳輸(如城域網
    的頭像 發表于 11-09 17:44 ?1192次閱讀
    皮線光纜選購指南:避開3大<b class='flag-5'>陷阱</b>,選對“光速通道”

    真正免費的AI生成PPT工具盤點:告別收費陷阱

    的戰斗機",其他9款工具也各有絕活,保證讓你告別收費陷阱,輕松做出專業級PPT! 一、AiPPT:一句話生成PPT的"時間管理大師" 一句話生成,一分鐘出片 作為北京餅干科技旗下的"AI+PPT"先鋒,AiPPT堪稱打工人救星。只需輸入一句話主題,AI就能在1分鐘內生成邏輯清晰、風
    的頭像 發表于 10-30 15:43 ?6541次閱讀
    真正免費的AI生成PPT工具盤點:告別收費<b class='flag-5'>陷阱</b>

    氣密性檢測儀廠家選擇指南:避開踩坑陷阱,找到最適合的合作伙伴

    現實往往更復雜。讓我們深入探討如何在眾多選擇中找到真正適合的合作伙伴。一、行業真相:不為人知的選擇陷阱陷阱一:精度數據的包裝藝術幾乎每個廠家都會宣稱自己的設備精度
    的頭像 發表于 08-26 11:56 ?769次閱讀
    氣密性檢測儀廠家選擇指南:避開踩坑<b class='flag-5'>陷阱</b>,找到最適合的合作伙伴

    Force-I QSCV技術在SiC MOSFET界面陷阱測量中的應用

    電容-電壓 (C-V) 測量廣泛用于半導體材料和器件表征,可提取氧化物電荷、界面陷阱、摻雜分布、平帶電壓等關鍵參數。傳統基于 SMU 施加電壓并測量電流的準靜態方法適用于硅 MOS,但在 SiC
    的頭像 發表于 08-25 15:06 ?4288次閱讀
    Force-I QSCV技術在SiC MOSFET界面<b class='flag-5'>陷阱</b>測量中的應用

    選購電池箱氣密性檢測儀,這些陷阱要避開-岳信儀器

    。然而,市場上產品良莠不齊,暗藏諸多陷阱,稍不注意就可能掉入“坑”中。部分不良商家為吸引眼球,夸大產品的檢測精度和速度。他們聲稱自己的電池箱氣密性檢測儀能達到極高的精
    的頭像 發表于 08-16 11:27 ?585次閱讀
    選購電池箱氣密性檢測儀,這些<b class='flag-5'>陷阱</b>要避開-岳信儀器

    待機功耗測試的“隱秘陷阱”:為什么你的測試結果可能不準確?

    本文導讀在家電、LED等行業,待機功耗測試看似簡單——選擇一臺高精度設備即可。但實際上,許多工程師都在無意中踩中測試“陷阱”:插排上的小紅燈、接線方式的選擇、量程檔位的設定...這些細節影響著你
    的頭像 發表于 07-22 11:37 ?815次閱讀
    待機功耗測試的“隱秘<b class='flag-5'>陷阱</b>”:為什么你的測試結果可能不準確?

    電商API常見錯誤排查指南:避免集成陷阱

    ,幫助您高效避免集成陷阱。內容基于真實電商API實踐,確保可靠性和實用性。 一、常見錯誤類型 電商API集成中,錯誤往往源于認證、數據、限流等環節。以下是高頻問題: 認證失敗錯誤 當API請求未通過身份驗證時,系統返回錯誤碼如401或
    的頭像 發表于 07-11 14:21 ?2036次閱讀
    電商API常見錯誤排查指南:避免集成<b class='flag-5'>陷阱</b>

    電氣控制設備廠家如何避免 BK 控制變壓器的 “陷阱

    BK機床控制變壓器電氣控制設備廠家們在追求發展的同時,正面臨著BK機床控制變壓器采購的“陷阱”,一不小心就會陷入困境,影響整個企業的運營與發展,這究竟是怎樣的情況呢?一些廠家在采購BK控制變壓器
    的頭像 發表于 07-04 13:45 ?487次閱讀
    電氣控制設備廠家如何避免 BK 控制變壓器的 “<b class='flag-5'>陷阱</b>

    必看!15個C語言常見陷阱及避坑指南

    ? C語言雖強大,但隱藏的“坑”也不少!稍不留神就會導致程序崩潰、數據異常。本文整理15個高頻陷阱,助你寫出更穩健的代碼! ? 陷阱1:運算符優先級混淆? 問題:運算符優先級不同可能導致計算順序錯誤
    的頭像 發表于 03-16 12:10 ?1781次閱讀

    整流橋選型十大陷阱:MDD從電流諧波到散熱設計的實戰解析

    關鍵陷阱,并提供系統性解決方案。一、電流有效值誤算:RMS值的隱形殺手案例:某10kW充電樁因按平均值選型,整流橋溫升達120℃炸裂。陷阱分析:輸入電流波形畸變(T
    的頭像 發表于 03-10 10:41 ?1188次閱讀
    整流橋選型十大<b class='flag-5'>陷阱</b>:MDD從電流諧波到散熱設計的實戰解析