私の問題は、hashMap.get(key)が呼び出されたときに内部LinkedListへの参照を返すHashMapが必要であるということです。単にキーに対応する値を返すだけではありません。JavaのHashMapsとリストの調整
私が集めたことから、LinkedHashMapは、二重リンクリストが各マップエントリを占有して衝突処理を行うことを可能にします。しかし、私はそれにマップされたすべての値をカプセル化している包括的なLinkedListへの参照を取得できるようにしたい(LinkedListを共有する各オブジェクトは、オーバーライドされたハッシュコード関数により非常に興味がある特定の機能も共有する)。
別の言い方をすれば、私はLinkedHashMapクラスに組み込まれているリンクリスト自動トラバーサルを避け、リスト自体の参照を操作可能にしたいと考えています。
linkedHashMap.put(key、value)を呼び出してLinkedListsの最後に新しい値を追加できるだけでなく、この参照を返すこともできます。
何か指摘していただければ幸いです。
「LinkedHashMapを使用すると、二重リンクされたリストが各マップエントリを占有して衝突処理を行うことができます」 - いいえ、LinkedHashMapに名前を付けたリンクリストは完全に異なるものです。衝突解決リストは、通常のHashMapに存在します。 – user2357112
'Map>' ??それはあなたのニーズに合っていますか? 'linkedHashMap.put(key、value)'は単純なgetとupdateのステップで行うことができます(しかし、同期していなければアトミックではありません) –
Antoniossss
'HashMap>'を使うのはなぜですか? –
user2357112