ArrayList allgemein halten

krgewb

Top Contributor
Ich habe eine Methode geschrieben, die bei einer ArrayList die Reihenfolge der Elemente nach einem von mir ausgedachten Algorithmus ändert. Die ArrayList enthält Objekte vom Typ Person.
Wenn ich will, dass bei einer ArrayList mit Objekten vom Typ Klassenzimmer die Reihenfogle geändert wird, muss ich eine neue Methode schreiben. Wie muss ich die Methode schreiben, damit sie für beliebige ArrayLists funktioniert?
 

KonradN

Super-Moderator
Mitarbeiter
Wenn Du eine beliebige Collection sortieren können willst, dann kannst Du ja als Parameter die Collection und einen Comparator übergeben. Wie das Aussehen kann, kannst Du Dir bei List.sort ansehen welches dann auf Arrays,sort geht:
openjdk-jdk11/src/java.base/share/classes/java/util/Collections.java at master · AdoptOpenJDK/openjdk-jdk11 (github.com)

Aber man kann hier ja problemlos eigene Sortieralgorithmen nutzen.

Edit: Also ganz wichtig: List at bereits eine entsprechende Methode, d.h. Du musst da nichts implementieren. Das war also nur, wenn Du es selbst auch noch einmal programmieren willst (zur Übung oder so).
 

krgewb

Top Contributor
Mir geht es ums Prinzip. Mit ArrayList<Object>() hat es nicht funktioniert. Ich dachte, dass alle Klassen von Object erben!?
Meine zweite Idee war Generics, also z.B. ArrayList<T>() aber da kenne ich mich nicht aus.
 

Oneixee5

Top Contributor
Wenn du beliebige Objekte in einer Collection sortieren willst, dann bietet es sich an, dass diese Objekte das Interface Comparable implementieren. Die Methode Collections.sort(myList); kann dann ohne Comparator aufgerufen werden.

Java:
public interface NameSort extends Comparable<NameSort> {

    String getName();

    @Override
    default int compareTo(final Sort o) {
        return this.getName().compareTo(o.getName());
    }
}

publich class MyRoom implements NameSort{
  
    public String getName() { ... }
}

publich class MyPerson implements NameSort{
  
    public String getName() { ... }
}

List<NameSort> myList = List.of(new MyRoom(), new MyPerson(), ...)
Collections.sort(myList);
 

krgewb

Top Contributor
Mir geht es ums Prinzip. Es soll auch für Methoden funktionieren, die nichts sortieren sondern irgendetwas anderes machen.
 

mihe7

Top Contributor
Mit ArrayList<Object>() hat es nicht funktioniert. Ich dachte, dass alle Klassen von Object erben!?
Das tun sie auch., aber Typparameter sind nicht kovariant sondern invariant. (s. https://openbook.rheinwerk-verlag.de/javainsel/11_005.html#u11.5.2)

Mir geht es ums Prinzip. Es soll auch für Methoden funktionieren, die nichts sortieren sondern irgendetwas anderes machen.
Ja, dafür verwendest Du Generics.

Hier zum Beispiel eine generische Methode:
Java:
public <T> void doSomething(List<T> list) {
    for (T element : list) {
        System.out.println(element);
    }
}
Das funktioniert, weil jedes T von Object abgeleitet sein muss. Mehr als die Methoden von Object kannst Du hier aber nicht verwenden, da über den Typ nicht mehr bekannt ist. Insbesondere im Zusammenhang mit Listen muss Dich oft aber gar nicht mehr interessieren.

Java:
public class Something<T> {
    private List<T> list;

    public Something(List<T> aList) {
        this.list = new ArrayList<>(aList);
    }
}
Erzeuge ich nun ein Something-Objekt mit dem Typ Number, kann ich eine List<Number> übergeben - nicht aber eine List<Integer>. Zwar ist Integer von Number abgeleitet, nicht aber List<Integer> von List<Number>.
Code:
jshell> List<Number> numbers = List.of(1,2,3)
numbers ==> [1, 2, 3]

jshell> new Something<Number>(numbers)
$8 ==> Something@28c97a5

jshell> List<Integer> ints = List.of(1,2,3)
ints ==> [1, 2, 3]

jshell> new Something<Number>(ints)
|  Error:
|  incompatible types: java.util.List<java.lang.Integer> cannot be converted to java.util.List<java.lang.Number>
|  new Something<Number>(ints)
|                        ^--^

Was man aber tun könnte, wäre die Elemente zu kopieren, dazu ändert man den Konstruktor wie folgt:
Java:
public class Something<T> {
    private List<T> list;

    public Something(List<? extends T> aList) { // aList ist eine Liste eines unbekannten Typs, der von T abgeleitet ist
        this.list = new ArrayList<>();
        for (T element : aList) {
            this.list.add(element);
        }
    }
}

Der Konstruktor bekommt also eine Liste, von der man weiß, dass die Elemente von T abgeleitet sind. Daher kann man der Liste Elemente vom Typ T entnehmen und der List<T> hinzufügen. Damit funktioniert jetzt auch
Code:
jshell> new Something<Number>(ints)
$11 ==> Something@6d5380c2

Nachtrag: im Beispiel dient die List<? extends T> als Quelle. Wenn es dagegen Ziel ist, verwendet man <? super T>, hier mal beides:
Java:
public static <T> void copy(List<? extends T> source, List<? super T> destination) {
    for (T element : source) {
        destination.add(element);
    }
}
Damit kann man zum Beispiel von einer List<Integer> in eine List<Number> kopieren.

Code:
jshell> ArrayList<Number> numbers = new ArrayList<>();
numbers ==> []

jshell> copy(ints, numbers)

jshell> numbers
numbers ==> [1, 2, 3]
 
Zuletzt bearbeitet:

KonradN

Super-Moderator
Mitarbeiter
Mir geht es ums Prinzip. Es soll auch für Methoden funktionieren, die nichts sortieren sondern irgendetwas anderes machen.
Das Prinzip ist doch immer das Gleiche: Egal, was Du machen willst: Du brauchst eine Methode, die es für den Typ, den Du da (zwingend) hast, durchführt.

Wenn Du als Typ nur Object vorgibst, dann hast Du nur die Möglichkeiten, die Object vorgibt. Wenn Dir das nicht ausreicht, dann musst Du eine entsprechende Methode bereit stellen, die das für Object macht.

Und genau das siehst Du bei der Lösung von dem sort. Um etwas sortieren zu können. muss das Argument vergleichbar sein:
static <T extends Comparable<? super T>> void sort(List<T> list)
==> Der Typ T muss Comparable implementieren, damit das gegeben ist.

Wenn das nicht gegeben ist, dann muss man eine andere Möglichkeit dafür vorgeben:
static <T> void sort(List<T> list, Comparator<? super T> c)
==> Jetzt ist das Comparable verschwunden. Und statt dessen wird das Comparator als zweites Argument vorgegeben.

Und das ist der generelle Ansatz - egal, was dabei gemacht werden soll. Entweder Du erzwingst ein Verhalten in den Elementen, die Du erwartest oder Du gibst die Möglichkeit, dieses Verhalten von außen beizusteuern.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Allgemein Array in eine ArrayList überführen? Java Basics - Anfänger-Themen 7
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
Mugetsu35 ArrayList Update ohne Index Java Basics - Anfänger-Themen 6
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
Z Java ArrayList speichert falsche Daten ab bzw. gibt falsche Daten aus? Java Basics - Anfänger-Themen 42
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
W ArrayList und toString Java Basics - Anfänger-Themen 17
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
M 2d ArrayList durchgehen Java Basics - Anfänger-Themen 2
Blkckroll45 Arraylist Java Basics - Anfänger-Themen 6
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
berserkerdq2 Geht collections.sort bei allen? Linkedhashset, ArrayList, HashSet etc. Java Basics - Anfänger-Themen 4
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
D Arraylist mit Komplexen Datentyp Java Basics - Anfänger-Themen 3
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
volcanos List & ArrayList nach Familiennamen abfragen Java Basics - Anfänger-Themen 57
M static ArrayList in non-static Java Basics - Anfänger-Themen 12
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
M ArrayList<TreeNode<T>> fortlaufende Nummerierung der Elemente Java Basics - Anfänger-Themen 5
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
S ArrayList Username und passwort mit JTextField eingaben abgleichen Java Basics - Anfänger-Themen 10
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
F Erste Schritte Zahlenreihe von Arraylist in 3erBlöcke sortiert in neue Arraylist Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
F Methode ArrayList mit Eingabewert Java Basics - Anfänger-Themen 2
J ArrayList add methode selbst programmieren Java Basics - Anfänger-Themen 10
K Erste Schritte Wie schnell ist LinkedHashMap im Vergleich zur ArrayList, wenn alle Entries durchlaufen werden? Java Basics - Anfänger-Themen 47
thobren jtable arraylist Java Basics - Anfänger-Themen 12
N Exception beim Verwenden von Arraylist? Java Basics - Anfänger-Themen 10
P Schiebefix - ArrayList überschreibt Daten Java Basics - Anfänger-Themen 3
Zeppi OOP ArrayList Java Basics - Anfänger-Themen 2
P ArrayList Java Basics - Anfänger-Themen 4
L ArrayList auf 4 Elemente begrenzen Java Basics - Anfänger-Themen 56
C ArrayList sortieren nach bestimmten Buchstaben in den Wörtern Java Basics - Anfänger-Themen 13
S Arraylist<Object> mit verschiedenen Objects ausgeben Java Basics - Anfänger-Themen 3
J ArrayList auf bereits vorhanden eintrag prüfen Java Basics - Anfänger-Themen 5
M For Schleife/ArrayList Java Basics - Anfänger-Themen 12
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
L Längstes Element einer ArrayList ausgeben Java Basics - Anfänger-Themen 9
S Aus verschachtelter ArrayList auf einen Wert zugreifen Java Basics - Anfänger-Themen 4
L Methoden ArrayList Werte hinzufügen und löschen Java Basics - Anfänger-Themen 32
M ArrayList in GUI ausgeben Java Basics - Anfänger-Themen 1
J Nur bestimmter Typ aus der ArrayList ausgeben. Java Basics - Anfänger-Themen 9
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
C Sortieren einer ArrayList Java Basics - Anfänger-Themen 2
krgewb ArrayList von ArrayList Java Basics - Anfänger-Themen 2
R ArrayList Problem Java Basics - Anfänger-Themen 6
jonny_2k12 Wie kann ich eine ArrayList aus einer Klasse in eine andere übergeben? Java Basics - Anfänger-Themen 21
O Namen (mit Umlauten und ß) in einer ArrayList suchen Java Basics - Anfänger-Themen 5
N Typebound Objekte einer Arraylist hinzufügen Java Basics - Anfänger-Themen 7
R Methoden ArrayList clonen wirft exception Java Basics - Anfänger-Themen 3
S ArrayList in andere Klasse übernhemen Java Basics - Anfänger-Themen 5
M Letztes Element einer ArrayList Java Basics - Anfänger-Themen 12
B Objektverwaltung mit ArrayList in einer seperaten Klasse Java Basics - Anfänger-Themen 24
I Sortiert eine HashMap nicht gleich wie eine ArrayList? Java Basics - Anfänger-Themen 1
I ArrayList erstellen innerhalb einer Zeile? Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17
V Collections ArrayList mit Comparator sortieren Java Basics - Anfänger-Themen 16
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
F java.util.ArrayList Java Basics - Anfänger-Themen 3
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
M Zugriff auf eine ArrayList in einer anderen Klasse Java Basics - Anfänger-Themen 4
P Arraylist zu einem Array bringen mit Verschachtelung Java Basics - Anfänger-Themen 11
N Methode mit einer Arraylist Java Basics - Anfänger-Themen 106
I ArrayList - Methode zum Speichern eines Eintrags in einer Datei Java Basics - Anfänger-Themen 17
H ArrayList Java Basics - Anfänger-Themen 7
D public ArrayList(Collection<? extends E> c); Java Basics - Anfänger-Themen 2
M JTextField in ArrayList speichern Java Basics - Anfänger-Themen 4
C ArrayList mit return zurückgeben Java Basics - Anfänger-Themen 13
K Zahlenfolge ArrayList Java Basics - Anfänger-Themen 3
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
I Klassen Eine ArrayList<Long>, die sich automatisch sortiert Java Basics - Anfänger-Themen 20
F Array in ArrayList ablegen Java Basics - Anfänger-Themen 3
V ArrayList Java Basics - Anfänger-Themen 1
Z Runden Arraylist Java Basics - Anfänger-Themen 9
X Frage zur einer ArrayList in einer ArrayList Java Basics - Anfänger-Themen 5
F Arraylist als Pfadausgabe Java Basics - Anfänger-Themen 10
L Daten aus ArrayList in Datenbank durchsuchen Java Basics - Anfänger-Themen 5
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
M Problem mit ArrayList Java Basics - Anfänger-Themen 32
X Objekte einer ArrayList richtig ausgeben? Java Basics - Anfänger-Themen 8
O Hashmap, ArrayList, LinkedList Java Basics - Anfänger-Themen 7
X Problem mit Arraylist in Arraylist Java Basics - Anfänger-Themen 2
O HashMap - ArrayList Java Basics - Anfänger-Themen 29
M UML-Klassendiagramm ArrayList Java Basics - Anfänger-Themen 1
O ArrayList oberflächig durchsuchen Java Basics - Anfänger-Themen 3
I "\n" aus ArrayList enfernen, aber wie?! Java Basics - Anfänger-Themen 4
V Collections Objekte einer ArrayList in der main() ausgeben Java Basics - Anfänger-Themen 9
Jackii ArrayList ausgabe ohne Dopplung Java Basics - Anfänger-Themen 11

Ähnliche Java Themen

Neue Themen


Oben