Objekte sortieren mit Comparable

f4814n

Mitglied
Hi,

zunächst, ja, ich habe gesehen, dass es hier Threads zu dem thema gibt jedoch hab ich es dennoch nicht ganz gecheckt und erbitte hiermit höflich Sonderbehandlung ;-)

Folgendes Problem:
Ich habe eine ArrayList<Clothing>. Clothing hat die Attributen Price, Type (String)...
Meine Aufgabe ist es, die Objekte nach ihren Namen (Type) zu sortieren. Offenbar brauche ich dazu einen Comparator oder Ähnliches. Leider hab ich damit NULL Erfahrung und kann das, was ich im Interent dazu gelesen habe nicht richtig adaptieren. So sieht das bisher aus (clothes ist der Name der ArrayList<Clothing>) :
Java:
	public ArrayList<Clothing> sortClothesByName() {
		
		for(int i =0; i<clothes.size(); i++){
			
			// ???
			
		}
		return clothes;

	}

Das ist die Klasse Clothing:

Java:
public abstract class Clothing{
	
	String color, type;
	float price;
	
	public String getColor() {
		return color;
	}
	public void setColor(String color) {
		this.color = color;
	}
	public String getType() {
		return type;
	}
	public void setType(String type) {
		this.type = type;
	}
	public float getPrice() {
		return price;
	}
	public void setPrice(float price) {
		this.price = price;
	}
}

Danke, freu mich auf Tipps.
 

Kevin94

Top Contributor
Es gibt in Java zwei einfache Möglichekeiten Listen zu sortieren, ohne selbst einen Algorithmus implementieren zu müssen. Deine erster Codeausschnitt ist also völlig überflüssig, das hat das JRE schon fertig.
a) Die zu Sortierenden Objekte implementiert Comparable. Dann kann man die Liste einfach an [JAPI]Collections.html#sort(java.util.List)[/JAPI] übergeben.
b) Man implementiert einen Compartor für die Klasse der zu Sortierenden Objekte und übergibt den zusammen der List an [JAPI]Collections.html#sort(java.util.List, java.util.Comparator)[/JAPI].

Welche von beiden Varianten man nimmt ist letzendlich eine Design-Entscheidung. Wenn es genau eine möglich Reihenfolge gibt empfiehlt sich a), wenn man nach verschiedenen Attributen sortieren können soll b). Der Code unterscheidet sich nur darin wie die Attribute referenziert werden, ob über this oder die zweite übergebene Referenz.

Für deinen Clothing würde sich für die Sortierung nach Type folgende Implementirung eines Comparators anbieten:
Java:
new Comparator<Clothing>(){
public int compare(Clothing a,Clothing b)
{
    return a.getType().compareTo(b.getType());
}
}

Das nutzt aus, das String selbst Comparable implementiert und die Konvention für die Rückgabewerte von compareTo und compare die selbe ist. Wenn du lieber Compareble nutzen willst, musst du nur die Signatur entsprechen ändern und a durch this ersetzen.
 

f4814n

Mitglied
Vielen Dank für die schnelle Antwort.

Ich habe es mittlerweile auch nochmal versucht und ein Beispiel aus dem Internet an meines angepasst und der JUnit Test läuft auch reibungsfrei durch. 100% verstehe ich es aber nicht...

in der Klasse, die die Arraylist erstellt steht dieser teil:

Java:
public ArrayList<Clothing> sortClothesByName() {
			Collections.sort(clothes, new SortType());

			return clothes;
	}

und dann stand in dem Beispiel, man soll eine eigene Klasse erstellen "SortType" in der dann das hier steht:
Java:
import java.util.Comparator;

public class SortType implements Comparator<Clothing>{

	@Override
	public int compare(Clothing c, Clothing c1) {
		return c.getType().compareTo(c1.getType());
	}
	
	

}

ist diese Extraklasse notwendig?
 
S

Spacerat

Gast
Ja, diese Extraklasse ist notwendig, zumindest für Sortierattribute, die von denen in "compareTo()" abweichen.
Der Sinn eines oder mehrerer Comparatoren ist es ja, Collections (bzw. Listen) auf verschiedene Arten sortieren zu können. Mit Comparable lässt sich ja nur eine Art fest implementieren.
 

f4814n

Mitglied
ok, ich glaube das habe ich soweit gecheckt, vielen Dank.

Wie ist das denn jetzt wenn ich eine HashMap habe? Dann sollte das ja eigentlich nicht funktionieren oder? Collections.sort(HashMap<>...) gibt es ja nicht...?!

Merci
 

Kevin94

Top Contributor
Nein, eine HashMap kann man nicht sortieren. Aber eine TreeMap, die kann man genau genommen auch nicht sortieren, die ist immer sortiert. Da gibt es wieder die selben Möglichkeit wie bei der List, nur das man das beim erzeugen der TreeMap festlegen muss: Entweder man übergibt einen Comparator an den Konstruktor oder man implementiert Comparable. Wenn keines von beiden der Fall ist wirft die TreeMap eine Exception wenn man Elemente hinzufügen will.
 
G

Gast2

Gast
Wie vom Vorposter erwähnt kannst du eine HashMap nicht sortieren. Du hast aber die Möglichkeit das EntrySet der HashMap zu sortieren.
 

f4814n

Mitglied
ja, ich miene mal in einer Aufgabe gelesen zu haben dass man eine HashMap nach dem Value sortieren solll das ging irgendwie mit diesem "EntrySet" konnte aber nicht viel damit anfangen... ich glaube man musste ein wort in chars zerlegen in eine hashmap speichern und dann alphabetisch ausgeben oder so ähnlich...
 
G

Gast2

Gast
Wo genau hast du denn da Probleme? An das EntrySet kommst du mit der Methode entrySet(). Als Rückgabe bekommst du ein Set, dass du per Collections.sort() sortieren kannst.
 
S

Spacerat

Gast
1. Wo steht, dass man HashMaps nach Values sortieren soll? (War warscheinlich Teil der Aufgabe...)
2. Sets lassen sich genauso wenig sortieren wie andere Collections ausser der List.
3. Man kann Maps nach Values sortieren und zwar indem man das ValueSet in eine List kopiert und mit 'nem entsprechenden Comparator (alternativ müssen die Values Comparable implementieren) an "Collections.sort()" übergibt. Selbiges funzt dann auch mit dem Entry- bzw. KeySet.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Interface Eigene Objekte in Listen sortieren mit Interface Comparable Java Basics - Anfänger-Themen 5
U Objekte in einer LinkedList sortieren Java Basics - Anfänger-Themen 5
R Objekte Vergleichen und Sortieren Java Basics - Anfänger-Themen 3
S Listen Objekte nach LocalDateTime sortieren Java Basics - Anfänger-Themen 2
C Objekte mit Parametern sortieren Java Basics - Anfänger-Themen 8
H 2 verschiedene Objekte in Liste mit Compareable sortieren Java Basics - Anfänger-Themen 7
I Objekte in einem Array sortieren Java Basics - Anfänger-Themen 19
O Objekte miteinander vergleichen und sortieren Java Basics - Anfänger-Themen 10
H Beim Vergleich/Sortieren mehr als zwei Objekte berücksichtigen Java Basics - Anfänger-Themen 14
W Objekte in einer Array sortieren Java Basics - Anfänger-Themen 3
B Objekte Sortieren Java Basics - Anfänger-Themen 30
S Objekte sortieren? Java Basics - Anfänger-Themen 5
G Die Objekte eine ArrayList sortieren Java Basics - Anfänger-Themen 50
G Objekte mit dem Attribut title mit Comparator sortieren Java Basics - Anfänger-Themen 5
A Objekte in ArrayList anhand Variable sortieren Java Basics - Anfänger-Themen 10
H Objekte in einer Hashtable am einfachsten sortieren Java Basics - Anfänger-Themen 13
M Integer Objekte nach Größe in einem Vector sortieren. Java Basics - Anfänger-Themen 2
I Zapier -> wie werden Objekte gespeichert? Java Basics - Anfänger-Themen 10
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
K Hab ich dass so richtig erklärt (Objekte und Referenzen)? Java Basics - Anfänger-Themen 5
J Objekte in JSON speichern?? Java Basics - Anfänger-Themen 1
I Objekte in ShareProject speichern um später zu nutzen Java Basics - Anfänger-Themen 4
J Objekte Java Basics - Anfänger-Themen 22
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
Hzrfa Objekte, Referenz Java Basics - Anfänger-Themen 5
T 3D Objekte verarbeiten Java Basics - Anfänger-Themen 2
N Welche Objekte kann man zu einem Set hinzufügen Java Basics - Anfänger-Themen 4
I XML einlesen und Objekte bekommen Java Basics - Anfänger-Themen 2
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Encera Zugriff auf Map-Objekte Java Basics - Anfänger-Themen 3
E Objekte löschen Java Basics - Anfänger-Themen 9
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
Encera Auf Objekte aus anderer Klassen zugreifen Java Basics - Anfänger-Themen 20
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
B Objekte verschwinden beim Übersetzen Java Basics - Anfänger-Themen 5
D Zwei verschiedene Intellij Projekte, wie benutze ich wechselseitig objekte Java Basics - Anfänger-Themen 8
E Rekursiv Objekte erzeugen - geht das? Java Basics - Anfänger-Themen 2
T Collections Sind Subklassen-Objekte in Listen mit Generics erlaubt? Java Basics - Anfänger-Themen 16
F Aus eingelesener Datei korrekt Objekte erzeugen Java Basics - Anfänger-Themen 5
G Übergeordnete Objekte abrufen Java Basics - Anfänger-Themen 9
B Bin komplett am verzweifeln :( Verkettete Liste die Objekte hat Attribut auslesen Java Basics - Anfänger-Themen 14
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
B Objekte, bspw. konkret Arraylists,manuell aus Speicher löschen? Java Basics - Anfänger-Themen 70
S Objekte von zwei klassen in zwei verschiedene Textdateien schreiben Java Basics - Anfänger-Themen 5
D Wie Objekte im JFrame frei bewegen lassen? Java Basics - Anfänger-Themen 3
Spandeli8 Erzeugte Objekte gegenüber Bildern hervorheben in Java Processing Java Basics - Anfänger-Themen 1
J Zwei Objekte vergleichen Java Basics - Anfänger-Themen 8
L Werte von Objekte addieren Java Basics - Anfänger-Themen 14
U Objekte in LinkedList löschen und editieren Java Basics - Anfänger-Themen 14
W Objekte über Scanner Input; ToString Probleme... Java Basics - Anfänger-Themen 4
J Problem mit einer Methode, die beliebig viele Objekte in Array speichern soll Java Basics - Anfänger-Themen 6
G Methoden Informationen aus zwei Objekte bekommen? Java Basics - Anfänger-Themen 6
P Globale Objekte Java Basics - Anfänger-Themen 2
C Nachträglich neue grafische Objekte hinzufügen Java Basics - Anfänger-Themen 7
D Interaktion zweier Objekte Java Basics - Anfänger-Themen 5
M Objekte in Array speichern und ausgeben Java Basics - Anfänger-Themen 17
S Objekte indiziert erstellen Java Basics - Anfänger-Themen 27
M Warum dürfen Objekte einer Klasse auf statische Variablen dieser Klasse referenzieren? Java Basics - Anfänger-Themen 10
M Objekte mittels equals vergleichen Java Basics - Anfänger-Themen 14
C Fernseher-Aufgabe (Methoden, Klassen und Objekte) Java Basics - Anfänger-Themen 63
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
A (Objekte Java Basics - Anfänger-Themen 6
Y Klassen Klassen und Objekte Java Basics - Anfänger-Themen 3
Y Klassen Klassen und Objekte mit set und get Java Basics - Anfänger-Themen 0
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
G Java Objekte auf Duplikate testen Java Basics - Anfänger-Themen 4
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
M Implementieren einer Datenstruktur, welche nur 5 Objekte speichert Java Basics - Anfänger-Themen 3
M Objekte miteinander vergleichen Java Basics - Anfänger-Themen 18
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
J Java GUI- Objekte Position per Quelltext bestimmen Java Basics - Anfänger-Themen 4
G Objekte in Methoden? Java Basics - Anfänger-Themen 13
H Auf Objekte bzw Variabeln aus einer anderen Methode zugreifen Java Basics - Anfänger-Themen 7
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
K Boolean in einer Methode um 2 Objekte zu vergleichen Java Basics - Anfänger-Themen 12
I Objekte Hilfe Java Basics - Anfänger-Themen 8
G Klassen und Objekte Java Basics - Anfänger-Themen 2
W Verschachtelte Objekte wieder auspacken Java Basics - Anfänger-Themen 3
R Attribute mehrerer Objekte ausgeben Java Basics - Anfänger-Themen 3
C Objekte und Konstruktoren Java Basics - Anfänger-Themen 2
F Erstellen zweier Objekte mit dem selben Inhalt Java Basics - Anfänger-Themen 1
O ObjectOutputStream Anzahl Objekte festhalten Java Basics - Anfänger-Themen 17
R Objekte aus Array als String + kommasepariert speichern Java Basics - Anfänger-Themen 12
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
J Best Practice Dateiinhalte validieren und auf Objekte mappen Java Basics - Anfänger-Themen 3
B Automatisch Objekte erzeugen mit verschiedenen Namen Java Basics - Anfänger-Themen 4
der_Schokomuffin Hilfe gesucht beim Thema Objekte übergeben! Java Basics - Anfänger-Themen 2
S Konstruktor, Objekte Java Basics - Anfänger-Themen 4
PaperHat Objekte in Array vergleichen Java Basics - Anfänger-Themen 9
B HTML Code / Seite auslesen und JAVA Objekte erstellen Java Basics - Anfänger-Themen 12
PaperHat Programmieraufgabe - Objekte in Objekten Java Basics - Anfänger-Themen 2
E Methode mit Parametern um Objekte zu übergeben Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
T Klassen Klassenübergreifende Objekte erstellen lassen Java Basics - Anfänger-Themen 5
A Objekte verknüpfen Java Basics - Anfänger-Themen 2
M Objekte mit einer Schleife mehrmals erzeugen Java Basics - Anfänger-Themen 17
B Klassen Alle Unter-Objekte durchlaufen in der Hauptklasse Java Basics - Anfänger-Themen 10
B Objekte zählen/ Vererbung/ Kopplung/ Interface/ Abstract Class Java Basics - Anfänger-Themen 5
S Zählen der Zeiger auf Objekte Java Basics - Anfänger-Themen 35
J Methoden Equals Methode für Integer und Objekte überschreiben? Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben