Probleme mit eigener Hashmap

Status
Nicht offen für weitere Antworten.

vogelstrauss

Mitglied
Hallo zusammen,

Ich bin momentan dabei, mir eine eigene Hashmap zu schreiben. Es funktioniert auch alles so weit. Um etwas in die Hashmap einzutragen, übergebe ich als Schlüssel einen String und Value ein Int. Wenn ich jetzt allerdings beispielsweise 28 Schlüssel eintrage, werden nicht alle 28 eingetragen sondern nur z.B. 25. Ich hab keine Ahnung woran das liegen könnte. Schon eingetragene Schlüssel werden nicht nochmal eingetragen und eigentlich sollten auch keine Schlüssel überschrieben werden. Vielleicht blickt von euch einer durch.
Java:
public class Hashmap{

	private Entry[] entry;
	private int index, counter = 0;

	public Hashmap(){
		init(100);
	}

	public Hashmap(int size){
		init(size);
	}

	private void init(int size){
		entry = new Entry[size];
		for (int i = 0; i < entry.length; i++){
			entry[i] = new Entry();
		}

	}

	private int hashing(String str){
		String alphNum = null, strNum = null, codeStr = null;
		int code = 0;
		char comp;
		char[] alphabet = {'a','b','c','d','e','f','g','h','i','j','k',
				'l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',' ','ä','ü','ö'};
		str = str.trim().toLowerCase();

		for (int i=0; i < str.length(); i++){
			for (int j=0; j < alphabet.length; j++){
				comp = str.charAt(i);
				if ( comp == alphabet[j]){
					alphNum = Integer.toString(j+1);
				}
				strNum = Integer.toString(i+1);
				codeStr = alphNum + strNum + alphNum;

			}
			code = code +  Integer.parseInt(codeStr);

		}
		return code;
	}

	public void put(String key, int v) {
	
			System.out.println(counter + "Länge: " + entry.length);
		  if (counter == entry.length){
		    Entry[] entryClone = new Entry[entry.length * 2]; 
		    for(int i=0; i<entryClone.length; i++){
		    	entryClone[i] = new Entry();
		    }
		    

		    System.arraycopy(entry, 0, entryClone, 0, entry.length);

		    entry = new Entry[entryClone.length];
		  
		    System.arraycopy(entryClone, 0, entry, 0, entryClone.length);
		    
		  }
		
		if (!containsKey(key)){
			entry[index].setKey(key);
			entry[index].setValue(v);
			entry[index].setReserved(true);
			counter += 1;
		}
//		showEntries();

	}

	public int get(String key){
		if (!containsKey(key)){
			return entry[index].getValue();
		}
		return -1;
	}

	public boolean containsKey(String key){
		key = key.trim().toLowerCase();
		index = hashing(key) % entry.length;
		while (entry[index].isReserved() && key.equals(entry[index].getKey())){
			index += 1 % (entry.length); 
		}
		if (key.equals(entry[index].getKey()) && entry[index].isReserved()) return true;
		else return false;
	}

	public void showEntries(){
		int count=0;
		for (int i=0; i < entry.length; i++){
			if((entry[i].getKey()) != null){
				System.out.println(entry[i].getKey() + "\t" + get(entry[i].getKey()));
				count++;
			}

		}
		System.out.println(count + " Entries");
	}

public static void main(String[] args){
		Hashmap map = new Hashmap();

		
		String[] test = {"Emperor Maredudds entrance hall", "Lady Aderyns dining room", 
				"Emperor Maredudds entrance hall", "Couple Kendalls tee room",
						"Emperor Maredudds entrance hall", "Countess Morwennas concert hall",
				"Lady Aderyns dining room", "Lord Bronwyns bedroom",
				"Lord Bronwyns bedroom", "Princess Cathryns dressing room",
				"Princess Cathryns dressing room", "Count Dylans training room",
				"Princess Cathryns dressing room", "Sir Gwythyrs treasure room",
				"Count Dylans training room", "Marchioness Emlyns kittchen",
				"Count Dylans training room", "Duke Gruffydds hall",
				"Marchioness Emlyns kittchen", "Count Dylans training room",
				"Marchioness Emlyns kittchen", "Earl Folands tower",
				"Earl Folands tower", "Lord Glendowers smoking room",
				"Earl Folands tower", "Lady Gwendolines ball room",
				"Lord Glendowers smoking room", "Lady Gwendolines ball room",
				"Lady Gwendolines ball room", "Duke Gruffydds hall",
				"Duke Gruffydds hall", "Marchioness Emlyns kittchen",
				"Sovereign Baroness Heulwens bath room", "Baroness Hyless store",
				"Baroness Hyless store", "Grand Duke Illtyds hunt room",
				"Baroness Hyless store", "Countess Ithels shrine",
				"Grand Duke Illtyds hunt room", "Sovereign Baroness Heulwens bath room",
				"Grand Duke Illtyds hunt room", "Countess Ithels shrine",
				"Couple Kendalls tee room", "Viscountess Lleucus rest room",
				"Couple Kendalls tee room", "Queen Mairwens dancing hall",
				"Couple Kendalls tee room", "Countess Morwennas concert hall",
				"Viscountess Lleucus rest room", "Archduke Llywellyn armoury",
				"Archduke Llywellyn armoury", "Sovereign Baroness Heulwens bath room",
				"Sovereign Baroness Heulwens bath room","Archduke Llywellyn armoury",
				"Archduke Llywellyn armoury", "Queen Mairwens dancing hall",
				"Countess Morwennas concert hall", "Couple Kendalls tee room",
				"Countess Morwennas concert hall", "Viceroy Neifions library",
				"Countess Morwennas concert hall", "Lady Sawyls dancing saloon",
				"Viceroy Neifions library", "Lady Olwyns gallery",
				"Olwyns gallery", "Viceroy Neifions library",
				"Lady Olwyns gallery", "Knight Pryces arsenal",
				"Knight Pryces arsenal", "Lady Olwyns gallery",
				"Knight Pryces arsenal", "Viscount Rhydderchs torture chamber",
				"Viscount Rhydderchs torture chamber", "Duchess Rhiannon sleeping room",
				"Lady Sawyls dancing saloon", "Vicereine Tiwlips sweets corner",
				"Vicereine Tiwlips sweets corner", "Lady Sawyls dancing saloon",
				"Vicereine Tiwlips sweets corner", "King Trevors assembly hall",
				"Vicereine Tiwlips sweets corner", "Esquire Yoraths hiding place",
				"King Trevors assembly hall", "Electoral prince Vaughans stable",
				"King Trevors assembly hall", "Lordliness Wynfors trophy chamber",
				"Electoral prince Vaughans stable", "Lordliness Wynfors trophy chamber",};
		
		for (int i= 0; i<test.length; i++){
			map.put(test[i], i);
		}

		map.showEntries();


	}




}

Die Klasse Entry:
Java:
public class Entry {
	
	private String key = null;
	private int value = -1;
	private boolean reserved = false;
	
	public void setValue(int v){
		this.value = v;
	}
	
	public void setKey(String k){
		this.key = k;
		
	}
	
	public String getKey(){
		
		return key;
	}
	
	public int getValue(){
		
		return value;
	}
	
	public boolean isReserved(){
		
		return this.reserved;
	}
	
	public void setReserved(boolean b){
		reserved = b;
		
	}

}

Ich bin dankbar für jeden Hinweis.

vogelstrauss
 
Zuletzt bearbeitet:
S

SlaterB

Gast
String liefert doch schon einen hashCode(),
den kannst du doch zumindest testweise verwenden, um deine Hash-Methode als Fehlerursache zu identifizieren

private int hashing(String str){
reutrn str.hashCode();
}

--------

in jedem Falle fehlt eine main-Methode mit den 28 Strings, wenn ich nicht ganz blind bin,
die zum Ausprobieren wäre doch deutlich besser als rein in der Theorie den Code anzuschauen
 

vogelstrauss

Mitglied
ja, dass mir String ein hashcode() bereitstellt ist mir klar. Ich wollte nur was angepasstes und eigenes. Werde es gleich mal ausprobieren, ob damit der Fehler auch auftritt.

Habe oben die main() noch nachträglich hinzugefügt.
 
Zuletzt bearbeitet:
S

SlaterB

Gast
containsKey() errechnet den index:
> index = hashing(key) % entry.length;
wie bei Hashfunktionen üblich, ist der aber nicht eindeutig,
sowohl "King Trevors assembly hall" als auch "Lady Gwendolines ball room" führen zu Index 78,
ungeprüft überschreibt dann einer von beiden den anderen älteren Eintrag, am Ende fehlt einer (insgesamt 4x)

zu jedem Index muss eine Liste von Einträgen vorhanden sein,
oder zumindest muss man an einen Entry per Referenz noch weitere Entries ranhängen können, quasi eine LinkedList,

bei get/ contains muss dann die ganze Liste zum Index geprüft werden,
Kollisionen gehören zu so einem Verfahren dazu

------

dass nur durch den Aufruf von containsKey() als Seiteneffekt das Klassenattribut index gesetzt wird,
ist fast noch ein größerer Schnitzer
 

vogelstrauss

Mitglied
Ok, Danke.
dein deispiel wäre dann ein Hashing mit Verkettung. Ich wollte es mit Openadressing versuchen. containesKey() sucht auch einen freien Platz, wenn der vom Hashcode generierte Platz nicht mehr frei ist und schreibt es an den nächsten freien Platz. Die Variable index sollte dann auf den Platz zeigen.


>76 freier Platz
>77 freier Platz
>78 King Trevors assembly hall > kein Platz mehr für "Lady Gwendolines ball room" also schreibs an den nächsten freien Platz.
>79 Lady Gwendolines ball room
 
Zuletzt bearbeitet:
S

SlaterB

Gast
ok, hab nicht so genau geschaut,
die while-Bedingung geht nur dann einen Platz weiter, wenn die Keys übereinstimmen, das ist gerade falsch,
wenn key.equals(entry.key) dann bist du fertig, dann ist das der richtige Index,

-----

index += 1 % (entry.length);
wird so nicht funktionieren,
teste das dochmal
int x = 99;
x += 2 % 100

------

wenn die Map ganz voll ist, droht eine Endlosschleife, da wird aber wohl vorher schon die Map vergrößert
 

vogelstrauss

Mitglied
Ok, danke. Man muss wohl index = (index+1) % entry.length schreiben.
die while-Bedingung geht nur dann einen Platz weiter, wenn die Keys übereinstimmen, das ist gerade falsch,
wenn key.equals(entry.key) dann bist du fertig, dann ist das der richtige Index,

Also kann ich es nur über meine isReserved-Methode überprüfen, ob der Platz belegt ist?
Ich stehe gerade ein wenig auf dem Schlauch. Verstehe aber das Problem. Die Keys können also den gleichen Hashcode haben aber sich nicht gleichen.
 
S

SlaterB

Gast
&& !key.equals(entry[index].getKey())
könnte schon eine Besserung sein gegenüber
&& key.equals(entry[index].getKey())
 

vogelstrauss

Mitglied
Ja, klar. Wenn der jetzige Schlüssel ungleich mit dem eingetragenen Schlüssel an der Stelle index ist, dann erhöhe den index um 1 und überprüfe den nächsten Platz.
Allerdings sagt mir meine Hashmap jetzt, dass alle eingetragen Schlüssel nicht vorhanden wären. Versteh ich nicht
 
S

SlaterB

Gast
das zweite equals im if danach hast du hoffentlich nicht auch verändert?
bau doch paar System.out.println ein, um zu verstehen, was genau verglichen wird
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Probleme mit eigener equals Methode Allgemeine Java-Themen 18
J Mein eigener Messenger und dessen Probleme Allgemeine Java-Themen 48
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0
R DBUnit Performance Probleme Allgemeine Java-Themen 0
S Probleme mit Collection Allgemeine Java-Themen 7
L Probleme mit Jar Allgemeine Java-Themen 6
N Zahlensysteme umrechnen; Probleme beim Umwandeln Allgemeine Java-Themen 4
K OOP OOP Gui Spiel + Vererbungen Probleme durch Nichtwissen!! Allgemeine Java-Themen 1
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Synchronized Probleme Allgemeine Java-Themen 7
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit dem filechooser Allgemeine Java-Themen 1
J Comperator Probleme Allgemeine Java-Themen 4
A Probleme beim auslesen von Quelltext (HTML) Allgemeine Java-Themen 5
S Probleme mit Webappplikation Allgemeine Java-Themen 5
L Plötzlich Probleme mit der JVM :( Allgemeine Java-Themen 6
S starke performance probleme des forums Allgemeine Java-Themen 10
K Probleme bei Berechnung der Komplexität Allgemeine Java-Themen 7
R JRE Ablaufdatum seit 7u10 - Probleme bei selbst ausgelieferter JRE bekannt? Allgemeine Java-Themen 3
H Reg Exp Probleme Allgemeine Java-Themen 5
M Classpath Probleme bei JAR Generierung Allgemeine Java-Themen 2
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
D Probleme bei for-Schleife Allgemeine Java-Themen 4
R Probleme mit Javadoc Allgemeine Java-Themen 2
G Gson Probleme Allgemeine Java-Themen 2
P KI für TicTacToe programmieren > Probleme Allgemeine Java-Themen 2
M Google App Engine macht Probleme Allgemeine Java-Themen 4
H Probleme mit finally-Block und close() Allgemeine Java-Themen 4
F 2d array probleme Allgemeine Java-Themen 2
M 3D-Grafik Probleme beim drehen von Objekten Allgemeine Java-Themen 9
T Interface Probleme Allgemeine Java-Themen 8
C Eclipse Probleme bei selbst erstelltem Algorithmus Allgemeine Java-Themen 2
M Probleme mit String in Label übergeben. Allgemeine Java-Themen 6
H MediaManager Fragen/Probleme Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben