Datentypen Probleme mit Vector.contains()

Curry

Aktives Mitglied
Moin Moin!

Ich habe eine Methode geschrieben, die ein Paar Integer-Werte als Array verpackt in ein Vector schreibt. Es sollen aber nur die Integer-Werte in den Vector geschrieben werden, wenn diese dort nicht schon vorhanden sind. Diese Prüfung funktioniert bei mir leider nicht und ich verstehe nicht weshalb.

Warum ist das so und was muss ich anderes machen?

Java:
public void addBook(int library_id, int book_id) {
		Integer[] array = new Integer[2];
		array[0] = library_id;
		array[1] = book_id;
		
		System.out.println("array.length = " + array.length);
		System.out.println("array.toString() = " + array.toString());
		System.out.println("_e.size() (nr. 1)" + _e.size());
		
		if(!_e.contains(array)) {
			_e.add(array);
			setChanged();
			notifyObservers();
		}
		
		System.out.println("_e.size() (nr. 2)" + _e.size());
	}
 

tfa

Top Contributor
So funktioniert das nicht. Du schaust nach, ob ein neu angelegtes Array schon im Vector ist. Das kann aber nicht sein, da alle Arrays verschiedene Objekte sind.

Ein paar Tipps:
1. Verwende keine Integer-Arrays sondern mach dir eine eigene Klasse (IntPair oder so). Da kannst du dann equals() und hashcode() entsprechend implementieren.
2. Verwende keinen Vector sondern das Interface List und z.B. ArrayList als Implementierung.
3. Für dieses Problem sind Listen uneffektiv, da sie ständig durchsucht werden müssen. Mach dich mit Sets und Maps vertraut, vielleicht passt das besser.
4. Verwende keine Unterstriche in Variablennamen. Das ist gegen die Code-Konventionen.
 

nrg

Top Contributor
hier ein Beispiel @Aldi:
Java:
import java.util.*;

public class StringArrayWrapper {
	private String[] array = {"abc", "123"};
	
	public static void main(String[] args) {
		List<String[]> list = new ArrayList<String[]>();
		list.add(new String[] {"abc", "123"});
		System.out.println(list.contains(new String[] {"abc", "123"}));
		
		List<StringArrayWrapper> list2 = new ArrayList<StringArrayWrapper>();
		list2.add(new StringArrayWrapper());
		System.out.println(list2.contains(new StringArrayWrapper()));
	}
	
	@Override
	public boolean equals(Object o) {
		StringArrayWrapper saw = (StringArrayWrapper)o;
		for (int i = 0; i < this.array.length; i++) {
			if (saw.array.length != this.array.length || !saw.array[i].equals(this.array[i]))
				return false;
		}
		return true;
	}
}

Ausgabe:

false
true
 

Curry

Aktives Mitglied
@tfa:

Danke für deine tollen Tipps! Ich habe jetzt eine Klasse "IntPair()" geschrieben (siehe unten) und deren Objekte speichere ich in einer HashSet. Weshalb eigentlich kein Vector? Wegen der Eigenschaft des Hashsets die Objekte einmalig zu speichern?

Java:
public class IntPair {
	
	private int a;
	private int b;
	
	public IntPair(int a, int b) {
		this.a = a;
		this.b = b;
	}
	
	@Override public int hashCode() {
		return this.a * 100 + this.b;
	}
	
	@Override public boolean equals( Object that ) {
		
		if( that == null ) {
			return false; 
		}
		
		if ( getClass() != that.getClass() ) {
			return false; 
		}
		
		if ( this.a != ((IntPair)that).a || this.b != ((IntPair)that).b ) {
			return false;
		}
		
		return true;
	}
	
	public int getA() {
		return this.a;
	}
	
	public int getB() {
		return this.b;
	}

Hast du noch Verbesserungsvorschläge für diese Klasse? Mich stören ja ein wenig die Namen der Eigenschaften "a" und "b". ;-)

Bezüglich der Code-Konventionen ist es dann sinnvoller die Namen der Eigenschaften durch "this." kenntlich zu machen?
 

tfa

Top Contributor
Das sieht doch schon sehr gut aus.

Weshalb eigentlich kein Vector? Wegen der Eigenschaft des Hashsets die Objekte einmalig zu speichern?
Ja, für mich sahen deine Anforderung so aus, als ob du jedes Paar nur einmal haben willst. Ich kenn allerdings das konkrete Problem nicht.
Einen Vector musst du jedes Mal von vorne bis hinten durchsuchen. Der Zugriff in ein HashSet passiert sofort.

Hast du noch Verbesserungsvorschläge für diese Klasse?
Nichts wichtiges. Du könntest die Member-Variablen final deklarieren - die Klasse ist ja offensichtlich immutable. Das final würde dafür sorgen, dass auch so bleibt und nicht aus Versehen durch irgendwelche Quelltextänderungen verloren geht. Außerdem gibt es einen Performance-Vorteil - zumindest theoretisch.

Die Berechnung des Hashcode kann man eventuell noch optimieren. Normalerweise nimmt man als Faktor eine Primzahl (statt 100). Das hilft dabei, Kollisionen zu vermeiden. Aus welchem Wertebereich sind denn die Integer?

Mich stören ja ein wenig die Namen der Eigenschaften "a" und "b".
Keine Ahnung, welche Bedeutung diese Werte haben. Da kann ich dir nicht helfen. Zur Not nenn sie eben "first" und "second" oder so.

Bezüglich der Code-Konventionen ist es dann sinnvoller die Namen der Eigenschaften durch "this." kenntlich zu machen?
Kann man machen. Meine IDE ist z.B. so eingestellt, dass das automatisch beim Abspeichern geschieht.
 

Curry

Aktives Mitglied
Ja, für mich sahen deine Anforderung so aus, als ob du jedes Paar nur einmal haben willst. Ich kenn allerdings das konkrete Problem nicht.
Einen Vector musst du jedes Mal von vorne bis hinten durchsuchen. Der Zugriff in ein HashSet passiert sofort.
Das hattest du richtig erkannt. Von daher bin ich mit dem HashSet auch sehr zufrieden!

Nichts wichtiges. Du könntest die Member-Variablen final deklarieren - die Klasse ist ja offensichtlich immutable. Das final würde dafür sorgen, dass auch so bleibt und nicht aus Versehen durch irgendwelche Quelltextänderungen verloren geht. Außerdem gibt es einen Performance-Vorteil - zumindest theoretisch.
Ja, die Klasse ist wirklich als immutable gedacht und ich habe die Eigenschaften soeben final deklariert.

Die Berechnung des Hashcode kann man eventuell noch optimieren. Normalerweise nimmt man als Faktor eine Primzahl (statt 100). Das hilft dabei, Kollisionen zu vermeiden. Aus welchem Wertebereich sind denn die Integer?
Diese ursprünglich gepostete Methode ist ein Teil eines ViewModels, in dem ich unter anderem speicher welche Tabs in einem JTabbedPane geöffnet sind. Eigentlich sollten dort nicht mehr 10 Tabs offen sein.

Keine Ahnung, welche Bedeutung diese Werte haben. Da kann ich dir nicht helfen. Zur Not nenn sie eben "first" und "second" oder so.
Das mit dem Namen ist nicht sooo wichtig. ;-)

Kann man machen. Meine IDE ist z.B. so eingestellt, dass das automatisch beim Abspeichern geschieht.
Welche IDE verwendest du? Diese Funktion finde ich sehr reizvoll. Ich verwende aktuell Eclipse.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
C Vector<Object> Probleme Java Basics - Anfänger-Themen 38
T Probleme mit Vector Java Basics - Anfänger-Themen 13
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
C Probleme mit Byte konvertieren nach int Java Basics - Anfänger-Themen 10
P Probleme mit NetBeans: Wie lässt sich jar. Datei an einem MacBook öffnen Java Basics - Anfänger-Themen 21
I Projekte in IDE untereinander sharen / Probleme beim Build Java Basics - Anfänger-Themen 8
MiMa Probleme mit Datentyp long ?? Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
B Quiz mit RMI Probleme mit RMI start Java Basics - Anfänger-Themen 4
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
V Probleme Guessing Game Java Basics - Anfänger-Themen 8
hebein PDF Ausdruck auf Drucker - Probleme mit Format Java Basics - Anfänger-Themen 17
R JMenu/JMenuItem Probleme Java Basics - Anfänger-Themen 2
B Static vs non static und Probleme daraus Java Basics - Anfänger-Themen 13
J Probleme mit dem Debugger Java Basics - Anfänger-Themen 4
I Probleme mit OutputStream - Datei lässt sich nicht öffnen Java Basics - Anfänger-Themen 4
J Probleme mit Kompilierung Java Basics - Anfänger-Themen 11
B Probleme mit Zugriff auf Dateisystem Windows 10 ( jFileChooser) Java Basics - Anfänger-Themen 17
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
C Probleme mit paintComponent Java Basics - Anfänger-Themen 13
P Probleme mit JUnit-Tests, es kommt was anderes raus als bei manuellen Tests Java Basics - Anfänger-Themen 5
E JavaFX Editor Probleme mit der Zwischenablage Java Basics - Anfänger-Themen 12
C Probleme mit dem Erstellen und Importieren von Packages Java Basics - Anfänger-Themen 6
3 OOP erste Versuche, OOP zu verstehen. Probleme mit gettern und settern Java Basics - Anfänger-Themen 4
R Erste Schritte Probleme bei 2D Spielfeld, mit einzufügender "Person" Java Basics - Anfänger-Themen 5
P Probleme bei der Installation von JavaFX Java Basics - Anfänger-Themen 3
S Mehrere Probleme im Code Java Basics - Anfänger-Themen 7
D Probleme mit JFrame und der Größe Java Basics - Anfänger-Themen 8
Dimax String Probleme Java Basics - Anfänger-Themen 12
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
Splayfer Java Array Probleme Java Basics - Anfänger-Themen 3
J Probleme bei IllegalArgumentException "werfen". Java Basics - Anfänger-Themen 1
K Probleme bei der Ausgabe - komme nicht weiter :/ Java Basics - Anfänger-Themen 15
X Probleme im Umgang mit PriorityQueue Java Basics - Anfänger-Themen 75
D Probleme mit dem Windowbuilder und JComboBox Java Basics - Anfänger-Themen 2
M Regex Probleme (mal wieder) Java Basics - Anfänger-Themen 3
tom.j85 TicTacToe - probleme beim Casten Java Basics - Anfänger-Themen 6
J Probleme mit Vererbung Java Basics - Anfänger-Themen 4
X Probleme mit Übungsaufgaben zu Zahlentypen Java Basics - Anfänger-Themen 4
G Probleme bei Aufgabe Java Basics - Anfänger-Themen 12
P Erste Schritte Probleme mit dem Programmieren Java Basics - Anfänger-Themen 12
B Probleme bei einer Aufgabe Java Basics - Anfänger-Themen 19
Franzi1001 Probleme mit Eclipse Java Basics - Anfänger-Themen 7
T Probleme bei Installation von JDK Java Basics - Anfänger-Themen 2
C Probleme mit String-Vergleich Java Basics - Anfänger-Themen 4
C Probleme bei Regex Java Basics - Anfänger-Themen 9
V Probleme mit Arrays Java Basics - Anfänger-Themen 8
D Kleine Probleme mit Split-Befehlen Java Basics - Anfänger-Themen 5
T Probleme mit Strings Java Basics - Anfänger-Themen 6
G Probleme bei Frame aufgaben Java Basics - Anfänger-Themen 6
N Probleme mit dem ActionListener Java Basics - Anfänger-Themen 4
D Probleme beim Kompelieren mache ich etwas falsch ? Java Basics - Anfänger-Themen 3
L Probleme mit Java Java Basics - Anfänger-Themen 3
S Probleme mit abspielen einer .wav Datei Java Basics - Anfänger-Themen 2
J Probleme bei der Umwandlung einer Farbe von Hex zu RGB Java Basics - Anfänger-Themen 8
K Probleme beim Programm schreiben - Lesen von Dateiinhalten -zaehlen von Wörtern/ Buchstaben Java Basics - Anfänger-Themen 4
M Probleme beim aktualisieren eines JPanels Java Basics - Anfänger-Themen 7
J Probleme beim Array ausgeben Java Basics - Anfänger-Themen 4
M Probleme bei rekursiver Zuordnung Java Basics - Anfänger-Themen 1
I Probleme mit 2 dimensionale Arrays Java Basics - Anfänger-Themen 3
H Best Practice View probleme Java Basics - Anfänger-Themen 2
B Probleme mit Kreisberechnung Java Basics - Anfänger-Themen 15
E Probleme mit Scanner Java Basics - Anfänger-Themen 4
J Eclipse Export Probleme Java Basics - Anfänger-Themen 25
M Probleme beim verwenden von Packages Java Basics - Anfänger-Themen 6
D Probleme mit der Übergabe einer BorderPane Java Basics - Anfänger-Themen 2
J Interface Probleme bei der Implementierung Java Basics - Anfänger-Themen 1
BlueFox Tabelle in der Konsole ausgeben - Probleme Java Basics - Anfänger-Themen 1
G Methoden Probleme beim Methodenaufruf Java Basics - Anfänger-Themen 2
V Klassen ObjectInputStream ->ReadObject Probleme Java Basics - Anfänger-Themen 5
P Probleme mit der Do-Schleife Java Basics - Anfänger-Themen 2
F Erste Schritte Compiling Probleme Java Basics - Anfänger-Themen 13
S Neuling und Probleme bei Schulaufgabe Java Basics - Anfänger-Themen 5
J Anfänger: ActionListener und ProcessBuilder machen Probleme Java Basics - Anfänger-Themen 6
S Erste Schritte 2D Grafik Probleme mit KeyListener. Java Basics - Anfänger-Themen 18
M Array mit eigenem Datentyp probleme beim übergeben Java Basics - Anfänger-Themen 6
M Probleme mit Eclipse Java Basics - Anfänger-Themen 20
G Probleme beim casten von double zu int Java Basics - Anfänger-Themen 3
E 2 Probleme - Datum & private finale Variablen Java Basics - Anfänger-Themen 5
S Compiler-Fehler javac hat Probleme mit Paketen unter OSX Java Basics - Anfänger-Themen 2
J Probleme beim schreiben von Dateien Java Basics - Anfänger-Themen 5
B Variablen Probleme mit Eclipse Java Basics - Anfänger-Themen 6
H Mouse- und KeyListener Probleme? Java Basics - Anfänger-Themen 5
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
I Probleme bei Verzeichnissanalyse Java Basics - Anfänger-Themen 12
F Probleme mit privaten Klassen (abstrakten Klassen) Java Basics - Anfänger-Themen 1
H Probleme mit Klassen...oder: Eine Uhr Java Basics - Anfänger-Themen 9
G Probleme mit Konsole Java Basics - Anfänger-Themen 4
S Probleme mit GamGrid Spiel-Erstellung => Actor reagiert nicht auf Tastatur Java Basics - Anfänger-Themen 2
G Probleme mit Eclipse oder der URL Klasse Java Basics - Anfänger-Themen 5
W Verständnis Probleme bei der while-Schleife und continue Java Basics - Anfänger-Themen 21
M Probleme mit Anzeigen von String in GUI und if-Anweisung Java Basics - Anfänger-Themen 9
T Konstruktor Probleme Java Basics - Anfänger-Themen 3
W Methoden Probleme mit der Scanner Methode Java Basics - Anfänger-Themen 2
F Ja Nein Abfrage und andere Probleme Java Basics - Anfänger-Themen 5
L If Anweisung mit ArrayList Probleme Java Basics - Anfänger-Themen 6
littles_de Simbad Simulator probleme mit Sensordaten... Java Basics - Anfänger-Themen 0

Ähnliche Java Themen

Neue Themen


Oben