compareTo in Verbinug mit Arrays.sort()

Status
Nicht offen für weitere Antworten.
K

koerschgen2001

Gast
Hallo erstmal,

bin ein Java Newbie und versuche gerade das mit compareTo(Object obj) zu verstehen, komme aber nicht ganz hinter die Sache.

Hier erstmal ein paar Codestücke.

Code:
// Kunde.java
public class Kunde implements Comparable {
	private String name;
	private String adresse;
	

	public Kunde(String name, String adresse) {
		this.name = name;
		this.adresse = adresse;
	}


public int compareTo(Object obj) {
		if (!(obj instanceof Kunde))
			throw new ClassCastException();
		return name.compareTo(((Kunde)obj).name);
	}

Code:
// Test.java
import java.util.*;

public class Test {
	public static void main(String[] args) {
		Kunde[] kunden = new Kunde[3];
		kunden[0] = new Kunde("Heinz Otto", "Hauptstr. 11, 12345 Entenhausen");
		kunden[1] = new Kunde("Karl Mustermann", "Hauptstr. 22, 12345 Entenhausen");
		kunden[2] = new Kunde("Günter Meier", "Traum Weg. 5, 12345 Entenhausen");

		Arrays.sort(kunden);

Ich verstehe nicht ganz was Methode compareTo macht.
So wie ich das sehe ist name z.B. Heinz Otto. ((Kunde)obj), obj steht für kunden. Nur in diesem Fall würde 0 zurückgegeben da beides, name.compareTo und (((Kunde)obj).name gleich sind.
Das würde in einer Sortierfunktion nicht viel Sinn ergeben. Was gibt "return name.compareTo(((Kunde)obj).name" zurück?

Da dieses Methode nirgendwo aufgerufen wird, muss Arrays.sort(kunden) anscheinend obj übergeben.
Aber was wird da übergeben.
Also erklärungen aus der Fachliteratur was dieses Methode macht habe ich genug gelesen. Ich bräuchte mal eine Erklärung die mir das aufschlüsselt.
 
S

SlaterB

Gast
hmm ist doch ganz einfach?

zwei Strings a="Auto", b="Zeitung" lassen sich vergleichen

a.compareTo(b) liefert was negatives und das bedeutet a ist lexikalische vor b
(geraten, was genau rauskommt siehe in die Beschreibung der Operation oder teste)


----------

bei zwei Kunden-Objekten ist das nun nicht mehr so einfach, niemand weiß wie die verglichen werden sollen,
es sei denn du implentierst compareTo und gibts darin an dass die beiden Strings vergleichen werden sollen

name.compareTo(((Kunde)obj).name)
entspricht
a.compareTo(b)

also gibt die Reihenfolge der Namen die Reihenfolge der Kunden-Objekte an, ganz einfach

------------

Arrays.sort(kunden);

ist irgendwie implementiert, Quicksort oder so, ist völlig egal,
es gilt allein: Arrays.sort(kunden); sortiert die MENGE der Kunden sofern es möglich ist, ZWEI Kunden miteinander zu vergleichen,

wenn das direkte Vergleichen erstmal geht ist es ja nur noch eine Frage eines guten Algorithmus das ganze Array zu sortieren
 
B

bygones

Gast
ich auch noch :)

compareTo sagt dem Algorithmus, welche Ordnung über den Objekten gilt. Bei Zahlen (Integer, Double usw) ist dies ja noch recht einleuchtend und logisch. Doch bei größeren Datenstrukturen natürlich bei weitem nicht.

D.h. compareTo sagt genau, ob das aktuelle Objekt größer, kleiner oder gleich dem übergebenen ist. Vor Java 1.5, also vor den Generics zeiten, musste die Methode so geschrieben werden, dass sie für alle möglichen Objekte gültig ist, also war der Parameter vom Typ Object.

Seit Java 1.5 mit den Generics, kann man sich die Sache erleichtern, in dem man den Typ selbst bestimmt
Code:
public class Kunde implements Comparable<Kunde> {
  ....

  public int compareTo(Kunde otherKunde) {
     // was auch immer
  }
}

Bei Strings ist die Ordnung die alphabetische Reihenfolge der Wörter.

Wie genau die Methode Arrays.sort implementiert ist, weiß ich nicht, ist auch im Grunde unwichtig. Bildlich kann man es sich so vorstellen, dass intern Objekte verglichen werden und aufgrund ihrer - im Comparator oder wenn sie Comparable sind - Ordnung sortiert
 

Lim_Dul

Top Contributor
koerschgen2001 hat gesagt.:
ClassCastException();
return name.compareTo(((Kunde)obj).name);

Ich splitte diese Zeile erstmal auf:
Code:
Kunde testObject = (Kunde)obj;
String kundenName = testObject.name;
return this.name.compareTo(kundenName);

Diese Zeile macht also nichts anderes, als von Kundenobjekten die Eigenschaft name zu vergleichen. Damit gilt, dass
Heinz Otto kleiner als Karl Mustermann, aber größer als Günter Meier ist.
 
K

koerschgen2001

Gast
In diese Richtung habe ich auch schon gedacht, war mir aber nicht ganz sicher.

Da ich jetzt aber bestätigt bekommen habe dass das so ist, glaube ich das mal.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Cassy3 Generics - CompareTo Java Basics - Anfänger-Themen 21
J compareTo()- und equals-Methode Java Basics - Anfänger-Themen 3
X compareTo Methode wird ignoriert Java Basics - Anfänger-Themen 7
O compareTo nach mehreren Kriterien Java Basics - Anfänger-Themen 13
J Hashmap langsamer als compareTo? Java Basics - Anfänger-Themen 23
B Methoden compare() und compareTo() Java Basics - Anfänger-Themen 1
P compareTo() Java Basics - Anfänger-Themen 3
C compareTo verwenden Java Basics - Anfänger-Themen 2
T Datentypen compareTo() u. equals() bei Strings Java Basics - Anfänger-Themen 3
K hashCode, compareTo vs. equals Java Basics - Anfänger-Themen 3
J Sortier alternativen mit der compareTo Methode? Java Basics - Anfänger-Themen 6
J TreeSet mit compareTo sortieren Java Basics - Anfänger-Themen 2
K compareTo(String arg) überschreiben Java Basics - Anfänger-Themen 4
N Compiler-Fehler Comparable / compareTo implementierung Java Basics - Anfänger-Themen 2
M CompareTo soll Datum sortieren Java Basics - Anfänger-Themen 2
S compareTo() und equals() Java Basics - Anfänger-Themen 6
A Objekte aus 2 Klassen mit compareTo() vergleichen Java Basics - Anfänger-Themen 7
K CompareTo zwei mal benutzen klappt nicht. Java Basics - Anfänger-Themen 2
1 HILFE! Strings mit CompareTo vergleichen Java Basics - Anfänger-Themen 3
R compareTo & equals Java Basics - Anfänger-Themen 10
T Methoden Wie compareTo() Methode implementieren? Java Basics - Anfänger-Themen 9
T Strings mit compareto vergleichen und array sortieren Java Basics - Anfänger-Themen 14
P Generischer Binärbaum (compareTo Frage) Java Basics - Anfänger-Themen 4
J Probleme mit Comparable, compareTo() Java Basics - Anfänger-Themen 2
R compareTo Liste sortieren Java Basics - Anfänger-Themen 5
L compareTo bei Strings? Java Basics - Anfänger-Themen 4
D OOP mit compareTo Array sortieren (aus zwei Klassen) Java Basics - Anfänger-Themen 3
T compareTo warum geht es nicht? Java Basics - Anfänger-Themen 2
W compareTo für 3 Strings Java Basics - Anfänger-Themen 11
M compareTo-Sortierungsproblem Java Basics - Anfänger-Themen 16
F compareTo - Sortierung nach 2 Argumenten Java Basics - Anfänger-Themen 10
G in compareTo umschreiben Java Basics - Anfänger-Themen 4
A Die "compareTo( )" methode Java Basics - Anfänger-Themen 16
J compareTo Java Basics - Anfänger-Themen 4
G compareTo Java Basics - Anfänger-Themen 12
T Wie geht das mit compareTo Java Basics - Anfänger-Themen 2
M o.compareTo(o) Java Basics - Anfänger-Themen 13
Bierhumpen compareTo. Wie setze ich es ein Java Basics - Anfänger-Themen 11
R compareTo Java Basics - Anfänger-Themen 2
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben