Interface Eigene Objekte in Listen sortieren mit Interface Comparable

Reggie()

Bekanntes Mitglied
Ich habe viel gesucht und kaum gute Erklärungen bzw. gute Code-Beispiele gefunden. Ich denke mein Code erklärt es ganz anschaulich. Allerdings habe ich auch eine Frage (unter dem Code)
Java:
import java.util.ArrayList;
import java.util.Collections;

public class Pizza implements Comparable<Pizza>{
    String name;
    int kalorien;
    boolean mitKaese;
  
    public Pizza(String name, int kalorien, boolean mitKaese) {
        this.name = name;
        this.kalorien = kalorien;
        this.mitKaese = mitKaese;
    }
   public static void main(String[] args) {
        ArrayList<Pizza> pizzen = new ArrayList<Pizza>();
        pizzen.add(new Pizza("Diavolo", 620, true));
        pizzen.add(new Pizza("Salami", 730, false));
        pizzen.add(new Pizza("Funghi ", 510, true));
        pizzen.add(new Pizza("Hawaii", 520, false));
        System.out.println("-----------VORHER---------");
        for (Pizza p : pizzen) {System.out.println(p.toString());}
        Collections.sort(pizzen);
        System.out.println("-----------NACHHER---------");
        for (Pizza p : pizzen) {System.out.println(p.toString());}
    }
   @Override
    public String toString() {
        String kaese = "ohne";
        if (mitKaese) {kaese = "mit";}
        return String.format("Pizza %s %s Käse hat %d Kalorien", this.name, kaese, this.kalorien);
    }
   @Override
    public int compareTo(Pizza p) {
        if (this.kalorien > p.kalorien) {
            return 1;
        } else if ((this.kalorien < p.kalorien)) {
            return -1;
        } else {
            return 0;
        }
    }
}
Erklärung: Die Methode Collections.sort(liste) benutzt standardmäßig die Methode int compareTo(Objekt o) für eine einfache Sortierung von Collections mit "einfachem Inhalt" wie int oder String. Will man Listen mit eigenen Objekte nach bestimmten Attributen sortieren, dann muss man das Interface Comparable implementieren und die Methode compareTo überschreiben.
AUSGABE:
Code:
-----------VORHER---------
Pizza Diavolo mit Käse hat 620 Kalorien
Pizza Salami ohne Käse hat 730 Kalorien
Pizza Funghi  mit Käse hat 510 Kalorien
Pizza Hawaii ohne Käse hat 520 Kalorien
-----------NACHHER---------
Pizza Funghi  mit Käse hat 510 Kalorien
Pizza Hawaii ohne Käse hat 520 Kalorien
Pizza Diavolo mit Käse hat 620 Kalorien
Pizza Salami ohne Käse hat 730 Kalorien

Frage: Wie kann man im Methodenaufruf bestimmen, nach welchem Attribut bzw. ob auf- oder absteigend sortiert werden soll.
 
Zuletzt bearbeitet:

Reggie()

Bekanntes Mitglied
Beispiel für manuelle Sortierung eigener Klasse auf verschiedene Art / Attribute
Java:
import java.util.ArrayList;

public class Pizza {
    String name;
    int kalorien;
    boolean mitKaese;
    static ArrayList<Pizza> pizzen = new ArrayList<Pizza>();
   
    public Pizza(String name, int kalorien, boolean mitKaese) {
        this.name = name;
        this.kalorien = kalorien;
        this.mitKaese = mitKaese;
    }
    public static void main(String[] args) {
        backePizza();
        zeigePizzen();
    }
    @Override
    public String toString() {
        String kaese = "ohne";
        if (mitKaese) {kaese = "mit";}
        return String.format("Pizza %s %s Käse hat %d Kalorien%n", this.name, kaese, this.kalorien);
    }
    public static void backePizza() {
        pizzen.add(new Pizza("Diavolo", 620, true));
        pizzen.add(new Pizza("Salami", 730, false));
        pizzen.add(new Pizza("Funghi ", 510, true));
        pizzen.add(new Pizza("Hawaii", 520, false));
    }
    public static void zeigePizzen() {
        //alphabetisch, kalorien, Käse
        String ausgabe = "---------UNSORTIERT---------\n";
        for (Pizza p : pizzen) {ausgabe += p.toString();}
        sortierePizzen(1);
        ausgabe +=   "---SORTIERT NACH KALORIEN---\n";
        for (Pizza p : pizzen) {ausgabe += p.toString();}
        sortierePizzen(2);
        ausgabe +=   "-----SORTIERT NACH KÄSE-----\n";
        for (Pizza p : pizzen) {ausgabe += p.toString();}
        sortierePizzen(0);
        ausgabe +=   "----SORTIERT ALPHABETISCH---\n";
        for (Pizza p : pizzen) {ausgabe += p.toString();}
        System.out.println(ausgabe);
    }
    public static void sortierePizzen(int sortierung) {
        //0 Name alphabetisch, 1 Kalorien 2 mit/ohne Käse
        int anz = pizzen.size();
        if (sortierung == 1) {
            int getauscht = 0;
            while (true) {
                for (int i=0; i<anz-1; i++) {
                    if (pizzen.get(i).kalorien > pizzen.get(i+1).kalorien) {
                        Pizza temp = pizzen.remove(i);
                        pizzen.add(i+1, temp);
                        getauscht++;
                    }
                }
                if (getauscht == 0) {
                    break;
                } else {
                    getauscht = 0;
                }
            }
        } else if (sortierung == 2) {
            int getauscht = 0;
            while (true) {
                for (int i=0; i<anz-1; i++) {
                    if (pizzen.get(i).mitKaese && pizzen.get(i+1).mitKaese == false) {
                        Pizza temp = pizzen.remove(i);
                        pizzen.add(temp);
                        getauscht++;
                    }
                }
                if (getauscht == 0) {
                    break;
                } else {
                    getauscht = 0;
                }
            }
        } else {
            int getauscht = 0;
            while (true) {
                for (int i=0; i<anz-1; i++) {
                    if (pizzen.get(i).name.compareTo(pizzen.get(i+1).name)>0) {
                        Pizza temp = pizzen.remove(i);
                        pizzen.add(i+1, temp);
                        getauscht++;
                    }
                }
                if (getauscht == 0) {
                    break;
                } else {
                    getauscht = 0;
                }
            }
        }
    }
}
 

stg

Top Contributor
Viel mehr kann man nicht "falsch" machen. Schau dir doch mal das Comparator-Interface an, wie ich zuvor vorgeschlagen hab.

Und: Pizza Hawaii und Pizza ohne Käse will eh keiner haben!
 

Flown

Administrator
Mitarbeiter
Mal zur Veranschaulichung, wie man das machen kann:
Java:
public class Test {
 
  public static void main(String... args) {
    List<Pizza> pizzen = new ArrayList<>();
    pizzen.add(new Pizza("Diavolo", 620, true));
    pizzen.add(new Pizza("Salami", 730, false));
    pizzen.add(new Pizza("Funghi ", 510, true));
    pizzen.add(new Pizza("Hawaii", 520, false));
    System.out.println("-----------VORHER---------");
    pizzen.forEach(System.out::println);
    System.out.println("-----------NATÜRLICHE ORDNUNG - KALORIEN---------");
    pizzen.sort(Comparator.naturalOrder());
    // oder pizzen.sort(null); oder Collections.sort(pizzen);
    pizzen.forEach(System.out::println);
    System.out.println("-----------NATÜRLICHE ORDNUNG - KALORIEN - ABSTEIGEND---------");
    pizzen.sort(Comparator.reverseOrder());
    pizzen.forEach(System.out::println);
    System.out.println("-----------NAME---------");
    pizzen.sort(Comparator.comparing(Pizza::getName, String.CASE_INSENSITIVE_ORDER));
    // ODER:
    pizzen.sort(new Comparator<Pizza>() {
      @Override
      public int compare(Pizza o1, Pizza o2) {
        return String.CASE_INSENSITIVE_ORDER.compare(o1.getName(), o2.getName());
      }
    });
    pizzen.forEach(System.out::println);
    System.out.println("-----------OHNE KÄSE FIRST & NACH NAME---------");
    pizzen.sort(Comparator.comparing(Pizza::isMitKaese).thenComparing(Pizza::getName, String.CASE_INSENSITIVE_ORDER));
    pizzen.forEach(System.out::println);
  }
 
}

class Pizza implements Comparable<Pizza> {
  private String name;
  private int kalorien;
  private boolean mitKaese;
 
  public Pizza(String name, int kalorien, boolean mitKaese) {
    this.name = name;
    this.kalorien = kalorien;
    this.mitKaese = mitKaese;
  }
 
  public String getName() {
    return name;
  }
 
  public int getKalorien() {
    return kalorien;
  }
 
  public boolean isMitKaese() {
    return mitKaese;
  }
 
  @Override
  public int compareTo(Pizza p) {
    return Integer.compare(kalorien, p.kalorien);
  }
 
  @Override
  public String toString() {
    return String.format("Pizza %s %s Käse hat %d Kalorien", this.name, mitKaese ? "mit" : "ohne", this.kalorien);
  }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Objekte in eigene Klasse auslagern Java Basics - Anfänger-Themen 2
B OOP Eigene Objekte in Arrays zusammenfassen Java Basics - Anfänger-Themen 3
B Eigene Objekte per Inhalt kopieren! Java Basics - Anfänger-Themen 2
Amina556 Eigene Klasse definieren Java Basics - Anfänger-Themen 9
T Eigene Exception - ohne werfen abfangen Java Basics - Anfänger-Themen 2
T Datentypen Eigene Datentypen Java Basics - Anfänger-Themen 15
low_in_the_head Eigene Exception nutzen Java Basics - Anfänger-Themen 4
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
L Meine erste eigene Exception Klasse Java Basics - Anfänger-Themen 10
D Attribut Telefonnummer - eigene Klasse oder String Java Basics - Anfänger-Themen 13
B JUnit 4: Wie man die eigene Liste testen kann [TDD] Java Basics - Anfänger-Themen 46
C eigene Methoden erstellen (Instanzmethoden) Java Basics - Anfänger-Themen 7
S Eigene LinkedList Klasse Java Basics - Anfänger-Themen 4
I Eigene Java Tools Nutzung Java Basics - Anfänger-Themen 6
G eigene Bibliothek einbinden Java Basics - Anfänger-Themen 1
K Eigene Annotations, Pre-/Post-/Call-Method Java Basics - Anfänger-Themen 6
O Erste Schritte Eigene charAt(i) Methode schreiben Java Basics - Anfänger-Themen 10
D Methoden Eigene Methode um alle Ausgaben aufzurufen Java Basics - Anfänger-Themen 17
L Eigene Exception schreiben bei zu langem Array Java Basics - Anfänger-Themen 10
P Maven und eigene Jars Java Basics - Anfänger-Themen 4
J Algorithmus - Strings auf eigene Reihenfolge miteinander vergleichen Java Basics - Anfänger-Themen 4
A Eigene Methoden entwicken Java Basics - Anfänger-Themen 3
F Klassen Eigene Exception Bedingungen festlegen Java Basics - Anfänger-Themen 2
H GSON-Bibliothek für eigene Programme benutzen Java Basics - Anfänger-Themen 2
H Klassen auf eigene Klasse zugreifen Java Basics - Anfänger-Themen 2
N Eclipse - eigene Icons unter ClassPath Resource Java Basics - Anfänger-Themen 0
N Eigene Stream Methoden implementieren Java Basics - Anfänger-Themen 3
R eigene Graphikbedienelemente Java Basics - Anfänger-Themen 8
V Generics / eigene Liste Java Basics - Anfänger-Themen 4
T Eigene Bedingung in IF-Bedingung Java Basics - Anfänger-Themen 22
P Java 8 & Eigene Applets Java Basics - Anfänger-Themen 3
E Best Practice Exaktes Rechnen mit (Pseudo-)Rationalen/Realen Zahlen. Operations Zuweisung für (eigene) Klassen Java Basics - Anfänger-Themen 3
G eigene Bibliothek in Java importieren Java Basics - Anfänger-Themen 5
D Klassen Eigene Klasse für ArrayList Java Basics - Anfänger-Themen 6
M Wann eigene implementierte HashCode Methode zwingend erforderlich? Java Basics - Anfänger-Themen 1
B Klassen Eigene "non static" Klasse in Main verwenden! Java Basics - Anfänger-Themen 12
P Vererbung Eigene HashMap Variante Java Basics - Anfänger-Themen 2
J Eigene Klasse für die Variablen? Java Basics - Anfänger-Themen 3
P Eigene Knöpfe mit eigenem Listener Java Basics - Anfänger-Themen 5
S Wann existiert eine Instanz (eigene Klasse) Java Basics - Anfänger-Themen 8
T Muss ein Parametertest immer eine eigene Testklasse sein? Java Basics - Anfänger-Themen 3
B Multithreading und eigene Queue entwickeln Java Basics - Anfänger-Themen 3
O GUI: Eigene Fenster "Form"? Java Basics - Anfänger-Themen 13
F Eigene LinkedList - toString Java Basics - Anfänger-Themen 10
O Denkanstöße für eigene Konfigurations-Datei Java Basics - Anfänger-Themen 12
SexyPenny90 Wieso ist diese eigene Equals-Methode schlecht? Java Basics - Anfänger-Themen 17
C eigene Exception Java Basics - Anfänger-Themen 4
M externe JARs in die eigene JAR einbinden Java Basics - Anfänger-Themen 9
V Klassen import - einfaches Umleiten auf eigene Klassen? Java Basics - Anfänger-Themen 8
S Eigene Exception Klasse - fehlender Konstruktor mit String Java Basics - Anfänger-Themen 3
B eigene klasse in listen eintragen Java Basics - Anfänger-Themen 6
S [JavaFX 2.1] - Eigene Sprachauswahl? Java Basics - Anfänger-Themen 4
K Klassen Eigene Exception verwenden Java Basics - Anfänger-Themen 9
J eigene packages bzw klassen verwenden Java Basics - Anfänger-Themen 25
E Eigene Stackklasse Java Basics - Anfänger-Themen 7
B Eigene Exceptions entwerfen Java Basics - Anfänger-Themen 3
S Eigene Exception Schreiben und Welche Auslösen wie ? Java Basics - Anfänger-Themen 7
P eigene kleine Datenverwaltung Java Basics - Anfänger-Themen 5
N Eigene Methoden-> Werte übergeben Java Basics - Anfänger-Themen 5
U Klassen Eigene Klassen importieren Java Basics - Anfänger-Themen 13
Kenan89 ActionListener in eigene Klasse Java Basics - Anfänger-Themen 8
E Object in eigene Klasse umwandeln? Java Basics - Anfänger-Themen 7
S Eigene Klassen addieren Java Basics - Anfänger-Themen 3
E Eigene class datum Java Basics - Anfänger-Themen 2
G Eigene MessageBox kreieren Java Basics - Anfänger-Themen 9
I Erste Schritte Eigene Fehlermeldungen bei Exceptions Java Basics - Anfänger-Themen 19
F Klassen Eigene Klasse definieren Java Basics - Anfänger-Themen 4
S Eigene KeyEvent-Mask erstellen Java Basics - Anfänger-Themen 4
X Eigene Libary Java Basics - Anfänger-Themen 2
Crashbreaker Eigene Java-Programm ohne hilfe des CMD starten Java Basics - Anfänger-Themen 11
A Klassen Eigene Datenklasse - Strings mit fixer Länge Java Basics - Anfänger-Themen 2
T eigene Exception Klasse Java Basics - Anfänger-Themen 12
G Shape um eigene Achse drehen Java Basics - Anfänger-Themen 2
P Vererbung Basisklasse soll eigene Methode benutzen Java Basics - Anfänger-Themen 38
F Eigene Klasse für die Keys von HashMap Java Basics - Anfänger-Themen 5
J Eigene kleine Datenbank programmieren Java Basics - Anfänger-Themen 2
G Eigene Klasse als Array, zugriff? Java Basics - Anfänger-Themen 2
xehpuk Ordner "Eigene Bilder" ansteuern Java Basics - Anfänger-Themen 3
V Sonderzeichen als eigene "Operatoren" im JTextField Java Basics - Anfänger-Themen 4
S Eigene Stack Klasse Java Basics - Anfänger-Themen 26
D Eigene equals methode schreiben Java Basics - Anfänger-Themen 4
dataframe OOP Eigene typisierte Liste Java Basics - Anfänger-Themen 3
W GUI als eigene Klasse oder in die Startklasse? Java Basics - Anfänger-Themen 21
T Konstruktor für eigene Klasse erstellen Java Basics - Anfänger-Themen 6
H Buttonbefehle in eigene Klasse schreiben Java Basics - Anfänger-Themen 8
M Datentypen Eigene iterierbare Liste Java Basics - Anfänger-Themen 4
G Eigene Klasse für externe Befehle - Warten auf Prozesse Java Basics - Anfänger-Themen 6
S Klassendiagramm - nur eigene Klassen? Java Basics - Anfänger-Themen 3
nrg Eigene simple List-Klasse programmieren Java Basics - Anfänger-Themen 3
C Eigene Interpreter-Programmiersprache mit Java Java Basics - Anfänger-Themen 17
B eigene Exception.... Java Basics - Anfänger-Themen 5
N Java Programm soll Datei in eigene jar schreiben Java Basics - Anfänger-Themen 13
F Eigene Exception StackTrace und Message ist leer warum??? Java Basics - Anfänger-Themen 3
M Eigene Pakete in Eclipse erstellen Java Basics - Anfänger-Themen 5
M Eigene Hash Funktion Java Basics - Anfänger-Themen 5
O Eigene Exceptions Java Basics - Anfänger-Themen 11
H eigene Schriftarten registrieren Java Basics - Anfänger-Themen 5
Kasoki Eigene Funktionen / Commands Java Basics - Anfänger-Themen 14
M Eigene LinkedList und Nodes Java Basics - Anfänger-Themen 20
S eigene Methoden in JDialog Java Basics - Anfänger-Themen 13

Ähnliche Java Themen

Neue Themen


Oben