Java Record基本用法詳解
一、Record 的誕生背景
Java 的 Record(記錄類)是 Java 14 引入的預(yù)覽特性,于 Java 16 正式標(biāo)準(zhǔn)化。其設(shè)計(jì)初衷是簡(jiǎn)化不可變數(shù)據(jù)類的定義,解決傳統(tǒng) POJO 類中大量樣板代碼(如構(gòu)造器、getter、equals、hashCode、toString 等)的問題。例如,一個(gè)簡(jiǎn)單的 Person 類在傳統(tǒng)寫法中需要 30+ 行代碼,而用 Record 只需一行。
傳統(tǒng)類 vs Record 類:
// 傳統(tǒng) POJO(30+ 行)
public class Person {
private final int id;
private final String name;
// 構(gòu)造器、getter、equals、hashCode、toString...
}
// Record 等效實(shí)現(xiàn)(1 行)
public record Person(int id, String name) {}通過 Record,開發(fā)者可以專注于數(shù)據(jù)本身,而非重復(fù)的模板代碼。
二、Record 的核心特性
不可變性
- Record 的所有字段默認(rèn)是
final的,創(chuàng)建后不可修改,天然線程安全。 - 適用于 DTO、配置項(xiàng)等需要數(shù)據(jù)一致性的場(chǎng)景。
- Record 的所有字段默認(rèn)是
自動(dòng)生成方法
- 編譯器自動(dòng)生成以下方法:
- 全參構(gòu)造器
- 字段訪問器(如
id()、name(),而非getId()) equals()、hashCode()、toString()。
- 編譯器自動(dòng)生成以下方法:
簡(jiǎn)潔語法
- 使用
record關(guān)鍵字定義,語法緊湊:public record Point(int x, int y) {}
- 使用
限制性設(shè)計(jì)
- Record 類是隱式
final的,不可被繼承。 - 不能聲明非靜態(tài)實(shí)例字段(僅允許通過參數(shù)列表定義字段)。
- Record 類是隱式
三、Record 的基本用法
1. 定義與實(shí)例化
public record User(String username, String email) {}
// 實(shí)例化
User user = new User("Alice", "alice@example.com");
System.out.println(user.username()); // 輸出 "Alice"2. 自定義方法
Record 允許添加自定義方法:
public record Circle(double radius) {
// 計(jì)算面積
public double area() {
return Math.PI * radius * radius;
}
}3. 參數(shù)校驗(yàn)(緊湊構(gòu)造器)
通過緊湊構(gòu)造器實(shí)現(xiàn)字段校驗(yàn):
public record Email(String address) {
public Email {
if (!address.contains("@")) {
throw new IllegalArgumentException("Invalid email");
}
}
}4. 實(shí)現(xiàn)接口與泛型
Record 可以實(shí)現(xiàn)接口,支持泛型:
public record Pair<T, U>(T first, U second) implements Serializable {
public String toJson() {
return "{ \"first\": \"" + first + "\", \"second\": \"" + second + "\" }";
}
}四、Record 的進(jìn)階應(yīng)用
替代 DTO/VO
- 快速定義 API 響應(yīng)模型:
public record ApiResponse<T>(int code, String message, T data) {}
- 快速定義 API 響應(yīng)模型:
模式匹配(Java 17+)
- 結(jié)合
instanceof解構(gòu)數(shù)據(jù):Object obj = new Point(3, 4); if (obj instanceof Point(int x, int y)) { System.out.println("坐標(biāo): (" + x + ", " + y + ")"); }
- 結(jié)合
數(shù)據(jù)庫映射
- 簡(jiǎn)化 JDBC 結(jié)果集處理:
try (ResultSet rs = statement.executeQuery()) { return new User(rs.getInt("id"), rs.getString("name")); }
- 簡(jiǎn)化 JDBC 結(jié)果集處理:
函數(shù)式編程
- 作為輕量級(jí)元組(如
Pair、Triple):record Pair<A, B>(A first, B second) {} List<Pair<String, Integer>> pairs = List.of(new Pair<>("Java", 1995));
- 作為輕量級(jí)元組(如
五、Record 與 Lombok 的對(duì)比
| 特性 | Record | Lombok |
|---|---|---|
| 不可變性 | 默認(rèn)支持 | 需手動(dòng)添加 final |
| 代碼生成 | 語言原生支持 | 依賴注解處理器 |
| 模式匹配 | 完全兼容 | 不支持 |
| 兼容性 | 需 JDK 16+ | 兼容舊版本 |
| 可變性 | 不可變 | 支持可變類(如 @Data) |
選擇建議:
- 優(yōu)先 Record:需不可變類、使用模式匹配或 JDK 16+ 環(huán)境。
- 選擇 Lombok:需可變類或兼容舊代碼。
六、注意事項(xiàng)
不可繼承性
- Record 不能繼承其他類(隱式繼承
java.lang.Record)。
- Record 不能繼承其他類(隱式繼承
字段限制
- 所有字段必須通過參數(shù)列表聲明,不支持動(dòng)態(tài)添加實(shí)例字段。
序列化
- 需顯式實(shí)現(xiàn)
Serializable接口。
- 需顯式實(shí)現(xiàn)
框架兼容性
- 部分框架(如舊版 Spring)可能需適配 Record 類型。
七、未來展望
- 模式匹配增強(qiáng):與
sealed class結(jié)合,構(gòu)建更嚴(yán)格的類型系統(tǒng)。 - 框架整合:Spring 等框架或默認(rèn)支持 Record 作為數(shù)據(jù)載體。
- 函數(shù)式擴(kuò)展:與 Stream、Optional 深度結(jié)合,提升代碼表現(xiàn)力。
總結(jié)
Java Record 通過極簡(jiǎn)語法和不可變性,顯著減少了數(shù)據(jù)類的樣板代碼,同時(shí)提升了代碼安全性和可維護(hù)性。其適用于 DTO、模式匹配、函數(shù)式編程等場(chǎng)景。
到此這篇關(guān)于Java Record基本用法詳解的文章就介紹到這了,更多相關(guān)Java Record內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java數(shù)據(jù)結(jié)構(gòu)之java實(shí)現(xiàn)棧
這篇文章主要介紹了java數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)棧,需要的朋友可以參考下2014-03-03
Java 并發(fā)編程ArrayBlockingQueue的實(shí)現(xiàn)
這篇文章主要介紹了Java 并發(fā)編程ArrayBlockingQueue的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
為什么Spring和IDEA都不推薦使用 @Autowired 注解
本文主要介紹了為什么Spring和IDEA都不推薦使用 @Autowired 注解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
java中request對(duì)象各種方法的使用實(shí)例分析
這篇文章主要介紹了java中request對(duì)象各種方法的使用,結(jié)合完整實(shí)例形式較為詳細(xì)的分析了request對(duì)象的功能及其常用方法的使用技巧,需要的朋友可以參考下2015-12-12
Spring Boot 基于注解的 Redis 緩存使用詳解
本篇文章主要介紹了Spring Boot 基于注解的 Redis 緩存使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05
解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題
這篇文章主要介紹了解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10

