在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

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

Android編程精選 ? 來源:ramostear ? 作者:樹下魅狐 ? 2021-10-28 11:29 ? 次閱讀
https://www.ramostear.com/blog/2020/04/28/uk1860p8.html 如果您正在閱讀此文,想必您對Project Lombok已經(jīng)有了一段時間的了解。您是否正準(zhǔn)備擁抱Lombok?還是正準(zhǔn)備將如此酷炫的項目推薦給你的團隊?如果您準(zhǔn)備那么做,不妨聽聽我在使用Lombok一年后的一些感受。我承認(rèn),Lombok是一個很不錯的Java庫,它可以讓你在少寫代碼的同時耍???,簡單的幾個注解,就可以干掉一大片模板代碼。但是,所有的源代碼很多時候是用來閱讀的,只有很少的時間是用來執(zhí)行的(你可以細(xì)品這句話)。 一年以前,我和大多數(shù)人都認(rèn)為Lombok的出現(xiàn)會讓Java的編碼體驗會更好,并極力的在我的團隊中推薦使用Lombok。一年以后,我開始對此產(chǎn)生顧慮,尤其是在我準(zhǔn)備為開源的博客系統(tǒng)Una-Boot升級Java版本時,我才意識到Lombok自己掉入了一個戲法陷阱。在我進(jìn)一步分析其源代碼并理解相關(guān)注解的工作原理后,發(fā)現(xiàn)我并不需要使用一個非標(biāo)準(zhǔn)的第三方庫將Java轉(zhuǎn)換為一個精巧而酷炫的語言。引入Lombok讓我的項目一時爽,但一時爽的代價是隨著項目推進(jìn),技術(shù)債務(wù)開始累積。接下來,我將用幾個大家耳熟能詳?shù)膱鼍?,重演自己是如何掉入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的模板代碼,這看起來像一個偏胖的人(不得不承認(rèn)Java是一個有缺陷的編程語言)。當(dāng)我們安裝好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就這點能耐?它還能讓你代碼的“身材”更苗條,更魔鬼。上面的代碼仍然還有改進(jìn)的空間,我們可以用@EqualsAndHashCod注解替換到equals和hashCode方法:

	

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

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

	

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

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

	

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

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

扭曲的審美,愛的隱患

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

1. JDK版本問題

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

2. 脅迫使用

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

3. 可讀性差

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

4. 代碼耦合度增加

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

5. 得不償失

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

總結(jié)

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2987

    瀏覽量

    107290
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4891

    瀏覽量

    70361

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

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

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    晶振選型三大陷阱:工作溫度、電壓與負(fù)載電容的隱藏矛盾

    在電子電路設(shè)計中,晶振作為關(guān)鍵的頻率控制元件,其選型是否恰當(dāng)直接影響到整個系統(tǒng)的性能和穩(wěn)定性。然而,在晶振選型過程中,存在著一些容易被忽視的陷阱,尤其是工作溫度、電壓與負(fù)載電容之間的隱藏矛盾,若不
    的頭像 發(fā)表于 05-22 15:43 ?136次閱讀
    晶振選型三大<b class='flag-5'>陷阱</b>:工作溫度、電壓與負(fù)載電容的隱藏矛盾

    揭秘Air780EPM開發(fā)陷阱:20個避坑指南與最佳解決方案

    重復(fù)報錯、資源過載等“隱形陷阱”消耗大量開發(fā)時間。本文基于經(jīng)驗提煉20個關(guān)鍵問題,傳授規(guī)避技巧與優(yōu)化方案,讓您的代碼更健壯。希望能幫助到需要的朋友,歡迎一起學(xué)習(xí)交流。 ? 最新開發(fā)資料詳見
    的頭像 發(fā)表于 05-21 16:04 ?181次閱讀
    揭秘Air780EPM開發(fā)<b class='flag-5'>陷阱</b>:20個避坑指南與最佳解決方案

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

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

    整流橋選型十大陷阱:MDD從電流諧波到散熱設(shè)計的實戰(zhàn)解析

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

    MOS管選型十大陷阱:參數(shù)誤讀引發(fā)的血淚教訓(xùn)MDD

    在電力電子設(shè)計中,MOS管選型失誤導(dǎo)致的硬件失效屢見不鮮。某光伏逆變器因忽視Coss參數(shù)引發(fā)炸管,直接損失50萬元。本文以真實案例為鑒,MDD辰達(dá)半導(dǎo)體帶您解析MOS管選型中的十大參數(shù)陷阱,為工程師
    的頭像 發(fā)表于 03-04 12:01 ?384次閱讀
    MOS管選型十大<b class='flag-5'>陷阱</b>:參數(shù)誤讀引發(fā)的血淚教訓(xùn)MDD

    自己搭建達(dá)龍云電腦,自己搭建達(dá)龍云電腦的詳細(xì)操作步驟

    隨著移動互聯(lián)網(wǎng)的快速發(fā)展,人們對計算設(shè)備的便攜性和靈活性提出了更高的要求。云電腦以其獨特的云架構(gòu),為用戶提供了全新的使用體驗。今天就為大家介紹自己搭建達(dá)龍云電腦的詳細(xì)操作步驟。 ? ?搭建自己的達(dá)龍
    的頭像 發(fā)表于 01-16 10:42 ?532次閱讀
    <b class='flag-5'>自己</b>搭建達(dá)龍云電腦,<b class='flag-5'>自己</b>搭建達(dá)龍云電腦的詳細(xì)操作步驟

    AN-348: 避開無源元件的陷阱

    電子發(fā)燒友網(wǎng)站提供《AN-348: 避開無源元件的陷阱.pdf》資料免費下載
    發(fā)表于 01-13 15:14 ?0次下載
    AN-348: 避開無源元件的<b class='flag-5'>陷阱</b>

    自己電腦搭建云主機,自己電腦如何搭建云主機?

    ? 如今,服務(wù)器遠(yuǎn)程連接技術(shù)正逐漸成為行業(yè)的新寵,它代表著服務(wù)器管理領(lǐng)域向高效化、智能化邁進(jìn)的發(fā)展趨勢。本文將帶你剖析自己電腦如何搭建云主機。 自己電腦搭建云主機是一種經(jīng)濟實惠且具有可行性的選擇
    的頭像 發(fā)表于 01-06 09:55 ?775次閱讀
    <b class='flag-5'>自己</b>電腦搭建云主機,<b class='flag-5'>自己</b>電腦如何搭建云主機?

    怎么自己搭建云電腦,怎么自己搭建云電腦的教程,云電腦是什么呢以及怎么鏈接

    探索怎么自己搭建云電腦的教程。 ? ?怎么自己搭建云電腦的教程: ? ?找臺性能尚可的電腦作為基礎(chǔ),安裝服務(wù)器級操作系統(tǒng),如WindowsServer2019。添加虛擬化功能,如Hyper-V,在里面創(chuàng)建虛擬機,分配資源(CPU、內(nèi)存、硬盤),安裝所需操作
    的頭像 發(fā)表于 12-26 14:39 ?402次閱讀
    怎么<b class='flag-5'>自己</b>搭建云電腦,怎么<b class='flag-5'>自己</b>搭建云電腦的教程,云電腦是什么呢以及怎么鏈接

    如何訓(xùn)練自己的LLM模型

    訓(xùn)練自己的大型語言模型(LLM)是一個復(fù)雜且資源密集的過程,涉及到大量的數(shù)據(jù)、計算資源和專業(yè)知識。以下是訓(xùn)練LLM模型的一般步驟,以及一些關(guān)鍵考慮因素: 定義目標(biāo)和需求 : 確定你的LLM將用
    的頭像 發(fā)表于 11-08 09:30 ?1436次閱讀

    如何訓(xùn)練自己的AI大模型

    訓(xùn)練自己的AI大模型是一個復(fù)雜且耗時的過程,涉及多個關(guān)鍵步驟。以下是一個詳細(xì)的訓(xùn)練流程: 一、明確需求和目標(biāo) 首先,需要明確自己的需求和目標(biāo)。不同的任務(wù)和應(yīng)用領(lǐng)域需要不同類型的AI模型,因此在選擇
    的頭像 發(fā)表于 10-23 15:07 ?4783次閱讀

    pytorch如何訓(xùn)練自己的數(shù)據(jù)

    本文將詳細(xì)介紹如何使用PyTorch框架來訓(xùn)練自己的數(shù)據(jù)。我們將從數(shù)據(jù)準(zhǔn)備、模型構(gòu)建、訓(xùn)練過程、評估和測試等方面進(jìn)行講解。 環(huán)境搭建 首先,我們需要安裝PyTorch??梢酝ㄟ^訪問PyTorch官網(wǎng)
    的頭像 發(fā)表于 07-11 10:04 ?976次閱讀

    PyTorch如何訓(xùn)練自己的數(shù)據(jù)集

    PyTorch是一個廣泛使用的深度學(xué)習(xí)框架,它以其靈活性、易用性和強大的動態(tài)圖特性而聞名。在訓(xùn)練深度學(xué)習(xí)模型時,數(shù)據(jù)集是不可或缺的組成部分。然而,很多時候,我們可能需要使用自己的數(shù)據(jù)集而不是現(xiàn)成
    的頭像 發(fā)表于 07-02 14:09 ?3406次閱讀

    Lombok注解引發(fā)的空指針問題分析

    一、問題描述 在一次上線后,日志中出現(xiàn)空指針的報錯,但是報錯代碼位置以及相應(yīng)工具類未進(jìn)行過修改,接下來進(jìn)一步分析。 以下為報錯堆棧信息: ? java.lang.NullPointerException: nullat net.sf.cglib.core.ReflectUtils.getMethodInfo(ReflectUtils.java:424) ~[cglib-3.1.jar:?]at net.sf.cglib.beans.BeanCopier$Generator.generateClass(BeanCopier.java:133) ~[cglib-3.1.jar:?]at net.sf.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25) ~[cglib-3.1.jar:?]at net.sf.cglib.core.AbstractClassGenerator.create(AbstractClassGene
    的頭像 發(fā)表于 06-23 09:30 ?1326次閱讀
    <b class='flag-5'>Lombok</b>注解引發(fā)的空指針問題分析

    請問vscode和eclipse哪個好使?

    如題,最近開發(fā)esp32,在windows環(huán)境下。 說實話,idf的開發(fā)環(huán)境比以前搭建起來簡單多了,無論是vscode還是eclipse里都有一鍵安裝的插件,從前的環(huán)境搭建失敗勸退多次噩夢不再重演
    發(fā)表于 06-21 06:43
    主站蜘蛛池模板: 啪啪免费网站视频观看 | 欧美肥胖女人bbwbbw视频 | 国产精品嫩草影院人体模特 | 国产婷婷综合丁香亚洲欧洲 | 窝窝午夜看片成人精品 | 日本午夜大片免费观看视频 | 天天干天天曰 | 91极品女神私人尤物在线播放 | 色天使视频 | 四虎影院国产精品 | 天堂网中文 | 三级网站在线看 | 4438x成人网最大色成网站 | 国产va精品免费观看 | 夭天干天天做天天免费看 | 一区二区三区视频观看 | 亚洲综合一区二区 | 天天干天天狠 | 色婷婷激情五月 | 亚洲视频1区 | 狠狠操夜夜 | 污污的黄色小说 | 亚洲国产欧美在线人成aaa | 国产精品va在线观看不 | 欧美日韩亚洲色图 | 400部大量精品情侣网站 | 欧美三级在线视频 | 国产精品欧美一区二区三区不卡 | 国产免费糟蹋美女视频 | 韩国三级理论在线观看视频 | 性生活黄色毛片 | 午夜久久久精品 | 最新亚洲人成网站在线影院 | 亚洲二区在线观看 | 亚洲午夜精品久久久久久抢 | 国产精品久久久久久久久久影院 | 久久水蜜桃网 | 天天舔天天干 | 天堂网www中文天堂在线 | 亚洲爽爽网 | 一级片免费看 |