“团队禁止使用Lombok”,被我狠狠的反驳了!
CTO 說了,用錯 @Autowired 和 @Resource 的人可以領(lǐng)盒飯了
用鴻蒙跑了個 hello world
來源 |?https://urlify.cn/MBZFF
今天,跟大家聊一聊,經(jīng)常在其它各個地方在說公司禁止使用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 工具完成這一過程。但這終究會消耗你很多的時間。
我的反駁:很多公司一旦確定JDK版本在很長的時間都不會改變(比如銀行項目很多都在用jdk1.6,你問他愿意升級到j(luò)dk11不?),現(xiàn)在都出到14版本了,你看有多少公司會升級!如現(xiàn)在很多公司都在用JDK1.8,任你出到JDK14,我依然繼續(xù)使用JDK1.8,等你出到JDK20時我相信Lombok肯定會支持更高的版本,那時兼容問題將不存在。
脅迫使用
當(dāng)你的源代碼中使用了 Lombok,恰好你的代碼又被其他的人所使用,那么依賴你代碼的人,也必須安裝 Lombok 插件 (不管他們喜不喜歡),同時還要花費時間去了解 Lombok 注解的使用情況,如果不那么做,代碼將無法正常運行。使用過 Lombok 之后,我發(fā)現(xiàn)這是一種很流氓的行為。
我的反駁:你裝不裝Lombok 插件不是你喜不喜歡,不是由你個人意愿決定的,這是工作,公司要求怎么做就要怎么做,這是規(guī)定。Lombok是一個非常簡單的知識點,十分鐘就能上手使用,你卻抱怨要花費時間學(xué)習(xí),作為程序員不是無時無刻都在學(xué)習(xí)嗎,你有這種抱怨只能你放棄程序員這個工作吧!
可讀性差
Lombok 隱藏了 JavaBean 封裝的細(xì)節(jié),如果你使用 @AllArgsConstructor 注解,它將提供一個巨型構(gòu)造器,讓外界有機會在初始化對象時修改類中所有的屬性。
首先,這是極其不安全的,因為類中某系屬性我們是不希望被修改的;
另外,如果某個類中有幾十個屬性存在,就會有一個包含幾十個參數(shù)的構(gòu)造器被 Lombok 注入到類中,這是不理智的行為;
其次,構(gòu)造器參數(shù)的順序完全由 Lombok 所以制,我們并不能操控,只有當(dāng)你需要調(diào)試時才發(fā)現(xiàn)有一個奇怪的 “小強” 在等著你;
最后,在運行代碼之前,所有 JavaBean 中的方法你只能想象他們長什么樣子,你并不能看見。
我的反駁:不滿意@AllArgsConstructor的做法你可以使用@Builder啊,這個支持你任意順序任意數(shù)量的創(chuàng)建對象,你不了解Lombok的其它用法就說它不好。你要看JavaBean中的方法?它有啥好看的,Getter和Setter方法有啥好看的,你不知道Getter和Setter方法長什么樣嗎?實在不明白有什么好看的?
代碼耦合度增加
當(dāng)你使用 Lombok 來編寫某一個模塊的代碼后,其余依賴此模塊的其他代碼都需要引入 Lombok 依賴,同時還需要在 IDE 中安裝 Lombok 的插件。
雖然 Lombok 的依賴包并不大,但就因為其中一個地方使用了 Lombok,其余所有的依賴方都要強制加入 Lombok 的 Jar 包,這是一種入侵式的耦合,如果再遇上 JDK 版本問題,這將是一場災(zāi)難。
我的反駁:
我們在使用其它框架時,那框架引入了不計其數(shù)的包,現(xiàn)在要引入一個很小的包都在斤斤計較,Lombok這么好用,幾乎所有項目都會使用到,這還需要強制引入嗎,我們自覺的都會在maven的parent依賴中統(tǒng)一引入了。
得不償失
使用 Lombok,一時覺得很爽,但它卻污染了你的代碼,破壞了 Java 代碼的完整性,可讀性和安全性,同時還增加的團(tuán)隊的技術(shù)債務(wù),這是一種弊大于利,得不償失的操作。如果你確實想讓自己的代碼更加精煉,同時又兼顧可讀性和編碼效率,不妨使用主流的 Scala 或 Kotlin 這一基于 JVM 的語言。
我的反駁:破壞了完整性?加上臃腫的Getter&Setter你卻嫌棄臃腫,不加你又說破壞代碼的完整性,你想怎么做。增加團(tuán)隊的技術(shù)債務(wù)?學(xué)個Lombok十分鐘的事情,有什么好增加的。要使用Kotlin? 一般公司都沒有這么激進(jìn)吧,現(xiàn)在Kotlin很多配套東西在企業(yè)中使用還不成熟吧。
來源 |?https://urlify.cn/MBZFF
大家還有什么不同觀點可以互相討論。
推薦文章1、14個項目!2、Spring Boot + Security + MyBatis + Thymeleaf + Activiti 快速開發(fā)平臺項目3、推薦幾個支付項目!4、寫博客能月入10K?5、一款基于 Spring Boot 的現(xiàn)代化社區(qū)(論壇/問答/社交網(wǎng)絡(luò)/博客)更多項目源碼 1、推薦兩個項目!2、重磅推薦:一套開源的網(wǎng)校系統(tǒng),無論是自建網(wǎng)校還是接副業(yè)都很方便 3、一款基于 Spring Boot 的現(xiàn)代化社區(qū)(論壇/問答/社交網(wǎng)絡(luò)/博客) 4、13K點贊都基于 Vue+Spring 前后端分離管理系統(tǒng)ELAdmin,大愛5、想接私活時薪再翻一倍,建議根據(jù)這幾個開源的SpringBoot總結(jié)
以上是生活随笔為你收集整理的“团队禁止使用Lombok”,被我狠狠的反驳了!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 超详细 kafka 入门(最佳实践)
- 下一篇: 你的 IDEA 酷不酷?