Frage zu HashCode Methode in Java

Maik.Neumann

Aktives Mitglied
Hallo !

Sehe ich das eigentlich richtig, dass die HashCode Methode in Java quasi für mehrere Objekte / Instanzen einer beliebigen Klasse identisch sein kann?

Also für einen Hashbasierten Container z.B. (wie die HashMap oder auch ein HashSet) stellt es quasi die Schublade / das Bulk dar, in dem mehrere Objekte / Instanzen einer Klasse abgelegt werden können?

Oder liefert hashcode für jedes Objekt / Instanzen einer Klasse immer unterschiedliche Werte zurück. In meinen bisherigen Testfällen habe ich immer unterschiedliche Werte von dieser Methode zurückgeliefert bekommen.

Danke und Gruß
 

Joose

Top Contributor
Klar ist die
Code:
hashCode
Methode für alle Objekte/Instanzen einer Klasse gleich ... der Wert den du zurück bekommst kann, muss aber nicht gleich sein! Das hängt von der Implementierung der Methode ab.

Du kannst diese Methode überschreiben und selbst implementieren was zurückgegeben wird.
Ob du nun einen "komplizierten", möglicherweise einzigartigen Wert ausrechnest oder einfach stupide "-1" zurück gibst ist egal!
 

Maik.Neumann

Aktives Mitglied
Ich verstehe deine Aussage nicht: "lar ist die hashCode Methode für alle Objekte/Instanzen einer Klasse gleich"

Mein folgender Code liefert mir dieses hier zurück:

Java:
Bier bier1 = new Bier("Astra", "Hamburg", 34f);
System.out.println(bier1);
Bier bier2 = new Bier("Flens", "Flensburg", 34f);
System.out.println(bier2);
Bier bier3 = new Bier("Becks", "Bremen", 34f);
System.out.println(bier3);

Ergebnis:
Java:
Bier@785bda13
Bier@564a5320
Bier@29978622

Das ist die Standardimplementierung von Java und es wurde nichts von mir überschrieben
 

Schesam

Bekanntes Mitglied
Es sind ja auch verschiedene Objekte --> Verschiedener Hash. Erzeuge mal 2 "Bier"-Objekte mit den gleichen Parametern, da sollte der gleiche Hash rauskommen :)
 

kaoZ

Top Contributor
Beim HashSet ist es aber so implementiert das ein Objekt welches als identisch identifiziert wird nicht hinzugefügt wird, sprich ,

kommt hierbei folgendes heraus :

Java:
import java.util.HashSet;

public class HashTest {
    
    static HashSet<Bier> set = new HashSet<>();

    class Bier{
        
        private String name;
        
        public Bier(String name) {
        
            this.name = name;
        }

        public String getName()     {return this.name;}

        @Override
        public boolean equals(Object o){
            return this.hashCode() == o.hashCode();
        }
        
        @Override
        public int hashCode(){
            return -1;
        }
    }

    public static void main(String[] args) {
        
        Bier eins = new HashTest().new Bier("Budweiser");
        Bier zwei = new HashTest().new Bier("Budweiser");
        
        System.out.println(eins.equals(zwei));
        
        System.out.println(eins.hashCode());
        System.out.println(zwei.hashCode());
        
        System.out.println(HashTest.set.add(eins)); //true
        System.out.println(HashTest.set.add(zwei)); //false
        
    }
}

Code:
true
-1
-1
true
false

Wie du sehen kannst werden hier beide Objekte wirklich als identisch behandelt, und dementsprechend auch das 2te nicht in das HashSet per add() hinzugefügt.

man sollte bei eigens designten Objekte eh immer
Code:
equals(Object o)
und
Code:
hashCode()
überschreiben, alleine schon da du sonst auf die Standardimplementierung zurückgreifen musst welche bei equals(Object o) z.B nur ein einfacher Referenzvergleich ist, der niemals gleich sein kann, schlussfolgernd daraus auch nicht der gleiche Speicherbereich alloziert wird und hashCode() niemals den gleichen Wert liefern kann ! auch nicht wenn beide Objekte (inhaltlich) identisch sind !

überschreibe ich z.B die Methoden nicht ergibt sich folgende Ausgabe bei gleicher Ausführung :

Code:
false
366712642
1829164700
true
true

objekte werden per equals() verglichen , der Referenzvergleich der Klasse Object liefert false, hashCode liefert die jeweilige textuelle Darstellung des allozierten Speicherbereiches ( Heap ) ,
die Objekte sind somit nicht Identisch, und werden beide dem HashSet hinzugefügt.

Immer daran denken , gleich != Identisch,

auch hier gern nochmal das Beispiel anhand von Zwillingen, nur weil Sie gleich aussehen ist es trotzdem nicht ein und die selbe Person ;)

Falls noch unklarheiten da sein sollten immer raus damit :)
 
Zuletzt bearbeitet:

Natac

Bekanntes Mitglied
Also erstmal sollte man den hash mit
Code:
hashCode()
abfragen. Ein
Code:
toString()
funktioniert nur so lange, wie es eben von der Subklasse nicht überschrieben ist, was es aber prinzipiell sein sollte um bei Debug-Ausgaben sinnvolle Texte zu erhalten.

Prinzipiell dient ein Hash ja dazu Objekte "vorzusortieren". Objekte mit gleichem Hash kommen in die gleichen "Schubladen". Innerhalb dieser Schubladen wird mit
Code:
equals()
dann das Objekt rausgesucht, was du wirklich haben willst (so arbeiten auch HashMap und HashSet).

Das geht natürlich umso schneller, je weniger Objekte sich eine Schublade teilen (gute Hashfunktion). Sind viele Objekte in einer Schublade, so dauert dies entsprechend lange und der Nutzen des Hash-Werts geht verloren (schlechte Hashfunktion).

Und das verschiedene Objekte den selben Hash haben MÜSSEN, kannst du dir schon daran überlegen, dass es mehr String-Instanzen gibt, als mögliche Hashwerte.

So haben folgende Strings alle den selben Hash-Wert (1952508096) :
Code:
AaAaAa
AaAaBB
AaBBAa
AaBBBB
BBAaAa
BBAaBB
BBBBAa
BBBBBB
(Beispiel ist von stackoverflow)


@kaoZ: Dir ist bewusst, dass durch
Java:
public int hashCode(){return -1;}

public boolean equals(Object o){
  return o.hashCode() == hashCode();
}
Bei dir ALLE Bier-Instanzen als zueinander gleich angesehen werden!? Finde das Beispiel unglücklich gewählt, da du damit gar nicht mehr zwischen Gleichheit und hash unterscheidest. Ich gebe dir Recht, dass man equals und hashCode auf jeden Fall überschreiben sollte. Aber in deinem Fall hätte ich doch lieber den namen des Bieres genommen:

Java:
public int hashCode(){return name.hashCode();}
public boolean equals(Object o){
  if(o == null)return false;
  if(o == this)return true;
  if(o.getClass() == getClass()){return name.equals(((Bier)o).name);
  return false;
}
 
Zuletzt bearbeitet:

kaoZ

Top Contributor
@kaoZ: Dir ist bewusst, dass durch

Ja ist es , es war nur ein sinnbildliches Beispiel..... damit war nicht gemeint das er die Methode so überschreiben soll...

Prinzipiell ging es nur darum das der TO erkennt das es sich in seinem Beispiel um verschiedene Objekte handelt, welche dadurch das diese nicht als identisch angesehen werden , trotzdem dem Set hinzugefügt werden, auch wenn Sie für ihn Optisch identisch erscheinen mögen.

[EDIT]Es war heute morgen schon recht früh ^^ mag sein das es nicht die sinnvollste Implementierung zu Anschauungszwecken war ;)[/EDIT]
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Frage zu equals() und hashCode() Java Basics - Anfänger-Themen 28
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben