Java レコード パターンは、Project Amber の一部として Java 16 で導入され、Java 21 ではデコンストラクターとパターン マッチングが追加されて強化されました。この機能により、Java アプリケーションでデータをより簡潔かつ柔軟に処理できるようになります。このチュートリアルでは、レコード パターンの概念、それがパターン マッチングにどのように役立つか、さまざまなコーディング例について説明します。
1. Java レコードの簡単な要約
レコード パターンに入る前に、Java レコードについて簡単にまとめてみましょう。レコードは、不変データを保持するために特別に設計された新しいタイプのクラスとして Java 14 に導入されました。データを使用してクラスを定義するためのより簡潔な構文が提供されるため、定型コードを記述する必要がなくなります。次の例では、名、姓、年齢の 3 つのフィールドを持つ「人」という名前のレコードを定義します。
レコード person(String firstName, String lastName, int age) {}
レコードは不変であるため、特定の特性が制限されます:
レコードはフィールドごとにコンストラクターとゲッター メソッドを自動的に生成するため、従来のクラスよりもデータ キャリアに適しています。
2.レコードパターンとは何ですか?
Java 21 で導入されたレコード パターンは、パターンの概念とレコードを組み合わせたもので、レコードの値を簡単に分解して抽出できるようにします。レコード パターンは、レコード クラス タイプと、テストが成功した場合にのみターゲット レコードから抽出された値が割り当てられるオプションのパターン変数で構成されます。
NULL 値はどのレコード パターンにも一致しないため、この場合パターン変数は初期化されません。
3.レコードデストラクター
デストラクターはコンストラクターの逆です。値を追加するのではなく、オブジェクトから値を抽出します。レコードのコンテキストでは、デストラクターは「デコンストラクター」と呼ばれます。これにより、レコード値を個々のコンポーネントに分解できます。次のフィールドを持つ「Name」という名前のレコードがあるとします:
顧客のレコード(String firstName, String lastName, int age) {}
次の例に示すように、デコンストラクターを使用して、「Customer」レコードのインスタンスからこれらのフィールドの値を抽出できます。
顧客 customer = new Customer("Jane", "Smith", 30); if (顧客インスタンスof Customer(String firstName, String lastName, int age)) {System.out.println("名: " + firstName); // ジェーン
System.out.println("姓: " + 姓); // スミス
System.out.println("年齢: " + 年齢); // 30
}
4. Switch ステートメントでパターンを記録するJava 16 では、instanceof ステートメントのパターン マッチングが導入されました。これは Java 21 でさらに拡張され、switch ステートメントが含まれます。複数のパターンを処理しながら、より簡潔で読みやすいコードが可能になります。
インターフェースアカウント{}
レコード SavingAccount (二重残高) はアカウント {}を実装します レコード CreditCardAccount(double CreditLimit, double used) はアカウント {}
を実装します レコード HomeLoanAccount(double totalAmount, double amountPaid) はアカウント {}
を実装します
アカウント account= new CreditCardAccount(10000, 1000);
スイッチ(形状){
ケース SavingAccount s:System.out.println("アカウント残高は " + 残高);
休憩;
ケースのクレジットカードアカウント c:
System.out.println("クレジット残高は次のとおりです: " + (creditLimit-used));
休憩;
ケース住宅ローン口座 h:
System.out.println("残高 " +(合計金額-支払金額));
休憩;
デフォルト:
System.out.println("不明なアカウント");
}
5.ネストされたパターン
単一レコードから値を抽出するだけでなく、レコード パターンをネストして、より複雑なレコードを処理することもできます。 「Account」という名前のレコードがあり、そのレコードには「Customer」タイプのフィールドと「Address」タイプの別のフィールドがあるとします。次の例に示すように、ネストされたレコード パターンを使用して、これらのフィールドの両方から値を抽出できます。顧客のレコード(String firstName, String lastName, int age) {}
顧客 customer = new Customer("John", "Doe", 25);
住所 address = new Address("123 Main St.","市", "州");
アカウント account = 新しいアカウント(顧客、住所);
if (アカウントインスタンス Account(顧客(fName, lName, age), Address(番地, 都市, 州))) {
System.out.println("名: " + fName); // ジョン
System.out.println("姓: " + lName); // ドウ
System.out.println("年齢: " + 年齢); // 25
System.out.println("住所: " + 番地 + ", " + 都市 + ", " + 州); // 123 Main St.、市、州
}
この例では、2 つのネストされたパターンを使用して、「Account」レコードの「Customer」フィールドと「Address」フィールドから値を抽出します。
6.コンポーネントのマッチング
レコード パターンを使用すると、パターン変数がレコードのコンポーネント名と一致する必要がないため、柔軟性が高まります。互換性がある限り、パターン マッチングは成功します。例:
顧客のレコード(文字列名、文字列姓、整数年齢) {}
アカウントを記録(顧客の顧客、住所アドレス){}
顧客 customer = new Customer("John", "Doe", 25);
if (顧客インスタンスof Customer(var fn, var ln, var age)) {
System.out.println("名: " + fn); // ジョン
System.out.println("姓: " + ln); // ドウ
System.out.println("年齢: " + 年齢); // 25
}
// ネストされたレコードコンポーネントにアクセスします
アカウント account = new Account(customer, new Address("123 Main St", "New York", "NY"));
if (アカウントインスタンスのアカウント(var cust, var address)) {
System.out.println("顧客: " + cust); // 顧客[名=ジョン、姓=ドウ、年齢=25]
System.out.println("アドレス: " + アドレス); // 住所[ストリート=123 Main St、都市=ニューヨーク、州=ニューヨーク]
}
ここで、パターン変数「fn」と「ln」は、「Customer」レコードの対応するコンポーネント名「fName」と「lName」とは異なります。これにより、レコード パターンがより柔軟になり、変数名との潜在的な競合が回避されます。
7.結論
結論として、Java レコード パターンは、レコードを分解し、そこから値を抽出する便利な方法を提供します。これにより、instanceof ステートメントと switch ステートメントでのパターン マッチングを処理しながら、コードがより簡潔でクリーンで読みやすくなります。レコード パターンをレコード デストラクターと組み合わせると、複雑なレコードをより堅牢に処理できるようになります。全体として、この機能はデータキャリアとしてのレコードの使用を強化し、Java プログラミングをより快適なものにします。
開発者は、MyExamCloud の 1Z0-830 模擬テストを使用して SE 21 Developer Certified Professional 試験の勉強をすることで、より多くの Java 21 機能を発見できます。
以上がJava レコード パターンとパターン マッチングの探索の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。