Heim > Java > javaLernprogramm > Wie implementiert man hashCode() effektiv für Sammlungen?

Wie implementiert man hashCode() effektiv für Sammlungen?

Mary-Kate Olsen
Freigeben: 2024-12-18 07:13:15
Original
254 Leute haben es durchsucht

How to Effectively Implement hashCode() for Collections?

Implementieren von hashCode() für Sammlungen

Die optimale Implementierung von hashCode() für eine Sammlung hängt von ihrem Verwendungsmuster ab. Ein weithin akzeptierter Ansatz, den Josh Bloch in seinem Buch „Effective Java“ vorschlägt, lautet jedoch wie folgt:

Algorithmus:

  1. Weisen Sie einen Wert ungleich Null zu Wert in ein ganzzahliges Variablenergebnis umwandeln.
  2. Für jedes Feld f, das in equal() verwendet wird Methode:

    • Berechnen Sie für boolesche Felder (f ? 0 : 1).
    • Berechnen Sie für numerische Felder (Byte, Char, Short, Int) (int)f.
    • Berechnen Sie für lange Felder (int)(f ^ (f >>> 32)).
    • Berechnen Sie für Float-Felder Float.floatToIntBits(f).
    • Berechnen Sie für Double-Felder Double.doubleToLongBits(f) und behandeln Sie das Ergebnis als Long-Wert.
    • Verwenden Sie für Objektfelder die Methode hashCode() des Objekts oder 0, wenn f null ist.
    • Für Array-Felder Berechnen Sie rekursiv die Hash-Werte jedes Elements und kombinieren Sie sie.
  3. Kombinieren Sie jeden Hash-Wert c mit dem Ergebnis: Ergebnis = 37 * Ergebnis c.
  4. Zurück Ergebnis.

Vorteile:

  • Bietet eine vernünftige Verteilung von Hashwerten für die meisten Anwendungsfälle.
  • Methodischer Ansatz gewährleistet Konsistenz Verhalten über verschiedene Datentypen hinweg.
  • Empfindlich gegenüber Änderungen, die sich auf das Objekt auswirken Gleichheit.

Das obige ist der detaillierte Inhalt vonWie implementiert man hashCode() effektiv für Sammlungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage