Java17中record替代Lombok部分功能使用場景探究
引言
在本站長期更新的Java新特性專欄中,已經(jīng)介紹過Java 16中開始支持的新特性:record的使用。
之前只是做了介紹,但沒有結(jié)合之前的編碼習(xí)慣或規(guī)范來聊聊未來的應(yīng)用變化。最近正好因為互相review一些合作伙伴的代碼,產(chǎn)生了一些討論話題,主要正針對于有了record
之后,其實之前有些用Lombok的場景,是可以替換掉了。
Lombok的威力
Lombok是我一直都喜歡使用的工具,因為它可以讓我們的代碼變的更加整潔。比如:當(dāng)我們要寫一個User對象的時候,如果不使用Lombok,往往需要寫這么多內(nèi)容:
public class User { private String username; private String email; private int userId; public User(String username, String email, int userId) { this.username = username; this.email = email; this.userId = userId; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public int getUserId() { return userId; } public void setUserId(int userId) { this.userId = userId; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; User user = (User) o; if (userId != user.userId) return false; if (username != null ? !username.equals(user.username) : user.username != null) return false; return email != null ? email.equals(user.email) : user.email == null; } @Override public int hashCode() { int result = username != null ? username.hashCode() : 0; result = 31 * result + (email != null ? email.hashCode() : 0); result = 31 * result + userId; return result; } @Override public String toString() { return "User{" + "username='" + username + '\'' + ", email='" + email + '\'' + ", userId=" + userId + '}'; } }
在有了Lombok之后呢,通過使用@Data
注解,可以將以上內(nèi)容縮減到只需要下面這幾行即可:
@Data public class User { private String username; private String email; private int userId; }
@Data
注解涵蓋了@Getter
、@Setter
、@EqualsAndHashCode
和 @toString
,所以一個注解就可以實現(xiàn)成員變量的Getter和Setter,equals和hashcode方法的重寫,以及toString的重寫。大大降低了代碼量,讓代碼看上去更加整潔。
Lombok的問題
雖然Lombok可以幫助我們少些很多代碼,但它依然有一些缺點,比如:
- Lombok并非Java官方提供,而是第三方依賴,依靠社區(qū)維護。對于較新的Java版本通常都會存在兼容性問題,容易產(chǎn)生一些不可預(yù)知的奇怪錯誤。
- IDE的兼容限制,并不是所有的IDE都可以完美兼容Lombok,所以可能也會因此產(chǎn)生一些奇怪的錯誤。
使用record來替代
在之前的Java 新特性:record一文中,已經(jīng)提到過record
類可以根據(jù)類的字段自動生成:構(gòu)造函數(shù)、equals()、hashCode() 和 toString()。這個功能就跟上面我們演示的Lombok中的@Data
非常類似。
寫法的話也非常簡單,只需要這樣一行即可搞定:
public record UserRecord(String username, String email, int userId) {}
可以看到該代碼的整潔度比Lombok的實現(xiàn)更加干凈。同時,最關(guān)鍵的一點,這是Java原生支持的,不需要引入任何第三方依賴!
record
類定義完成了,具體使用的話就跟平時使用其他類一樣,去創(chuàng)建實例和調(diào)用方法即可,比如下面這樣:
UserRecord userRecord = new UserRecord("didi", "didi@didispace.com", 35); System.out.println(userRecord.email()); System.out.println(userRecord.toString());
只是,我們在使用的時候需要了解record
自動生成的代碼與Lombok的區(qū)別,就能馬上上手。
比如,從上面的例子中我們可以看到一個區(qū)別:獲取成員變量email
的時候,這里并不想傳統(tǒng)getter那樣以getEmail()
的形式生成。
哪些情況替代不了?
record
類已經(jīng)很強大,但目前并不能完全替代Lombok。主要原因如下:
record
中定義的成員變量是final
類型的,初始化后就不能修改了record
類不能被繼承,所以也無法進一步擴展
因此,在用record
替代Lombok的時候,更多用來定義靜態(tài)變量,而不是可能會變化的實例變量。但是,由于record
中也可以定義函數(shù),所以對于一些對成員計算獲得的內(nèi)容,也可以實現(xiàn)和使用。
總結(jié)
Lombok
和record
都可以幫助我們編寫更加整潔的代碼。前者是第三方庫,可能存在一些不可預(yù)知的問題和IDE兼容問題,但功能更加全面和強大;后者屬于Java原生的能力,功能雖弱一些,但用好它也能幫助我們減少很多代碼的編寫,且IDE兼容性更好。
以上就是使用Java 17中的record替代Lombok的部分功能的詳細內(nèi)容,更多關(guān)于使用Java 17中的record替代Lombok的部分功能的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java高級用法中的JNA類型映射注意細節(jié)及使用問題
本文介紹了在使用JNA方法映射中應(yīng)該注意的一些細節(jié)和具體的使用問題,對java??JNA類型映射注意細節(jié)感興趣的朋友一起看看吧2022-04-04關(guān)于Unsupported Media Type的解決方案
在Web開發(fā)中,415錯誤表示服務(wù)器無法處理請求附帶的媒體格式,本文介紹了導(dǎo)致HTTP 415錯誤的原因以及解決該問題的兩種方法,首先,415錯誤通常是由于客戶端請求的內(nèi)容類型與服務(wù)器期望的不匹配引起的,例如,服務(wù)器可能期望JSON格式的數(shù)據(jù)2024-10-10Java案例實現(xiàn)不重復(fù)的隨機數(shù)
這篇文章主要介紹了Java案例實現(xiàn)不重復(fù)的隨機數(shù),通過創(chuàng)建Set集合對象,可以使用HashSet也可以使用TreeSet,區(qū)別在于TreeSet是排序后的,創(chuàng)建隨機數(shù)對象,獲取一個隨機數(shù)去重等操作,需要的朋友可以參考一下2022-04-04解決使用redisTemplate高并發(fā)下連接池滿的問題
這篇文章主要介紹了解決使用redisTemplate高并發(fā)下連接池滿的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12