HashMap と Java のマップの違い
Java でマップ コレクションを作成する場合、通常は HashMap クラスを使用します。ただし、Map インターフェイスとして宣言することもできます。ここで疑問が生じます: これら 2 つのアプローチの違いは何ですか?
主な違いは、オブジェクトへのアクセスのタイプにあります。 HashMap を使用すると、HashMap インターフェイスを備えたオブジェクトが作成されますが、Map を使用すると、同じオブジェクトに Map インターフェイスが提供されます。どちらの場合でも、基礎となるオブジェクトは同じままです。
Map インターフェイスを使用する利点は、それを使用するコードとのコントラクトを破ることなく、基礎となる実装を変更できることです。マップが HashMap として宣言されている場合、実装を変更するにはコントラクトを更新する必要があります。
説明のために、サブクラスと共有される内部マップを含むクラス Foo の例を考えてみましょう。 Foo が HashMaps で初期化され、サブクラス メソッドが宣言された HashMap 型を使用して Things と moreThings の両方を処理する場合、TreeMap を使用するように Foo を変更するとコードが破損します。
ただし、Foo が Things と moreThings を Map ではなく Map として宣言した場合HashMap、Foo とサブクラスの両方は、実装が次のように変更されても影響を受けません。 TreeMap.
したがって、特定の実装を使用する特別な理由がない限り、最も一般的なインターフェイス (Java の Map) にコーディングすることがベスト プラクティスと考えられます。このアプローチにより、柔軟性が強化され、実装の変更に対する復元力が確保されます。
以上がJava では「HashMap」と「Map」をいつ使用する必要がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。