Warum Java keine SortedList hat
Im Gegensatz zu SortedSet und SortedMap im Java Collections-Framework stellt Java keine dedizierte SortedList bereit. Trotz dieser Auslassung bietet Java Sortierfunktionen über die Methode java.util.Collections.sort().
Gründe für die Auslassung
Das Fehlen einer SortedList ist darauf zurückzuführen aus der grundlegenden Natur von Listeniteratoren. Listeniteratoren legen Wert darauf, die Einfügereihenfolge von Elementen beizubehalten. Sortieren hingegen kann als eine Manipulation der Datenstruktur angesehen werden, die die Reihenfolge der Elemente ändert.
Alternativen zu SortedList
-
SortedSet und Multisets (Taschen):
- SortedSet automatisiert das Sortieren beim Einfügen von Elementen, sodass keine manuelle Sortierung erforderlich ist.
- TreeMultiset (eine Multiset-Implementierung) ermöglicht das Duplizieren von Elementen unter Beibehaltung der Sortierung order.
-
Collections.sort():
- Sortiert Listeninstanzen durch Ändern ihrer internen Datenstruktur.
- Akzeptiert Komparatoren für benutzerdefinierte Sortierung und ermöglicht eine gebietsschemaabhängige Zeichenfolgensortierung, z Instanz.
-
PriorityQueue:
- Obwohl PriorityQueue kein direkter Ersatz für eine SortedList ist, bietet PriorityQueue ein geeignetes sortiertes Warteschlangenverhalten für bestimmte Anwendungsfälle.
- Die Iteration durch eine PriorityQueue gibt Elemente sortiert zurück order.
-
Benutzerdefinierte Implementierung:
- Benutzer können ihre eigene SortedList erstellen, indem sie die AbstractList-Klasse erweitern und das Add überschreiben und Sortiermethoden.
- Diese Option wird nicht empfohlen, da sie gegen den Listenschnittstellenvertrag verstößt und keine wesentlichen Vorteile gegenüber bestehenden bietet Lösungen.
Das obige ist der detaillierte Inhalt vonWarum hat Java keine SortedList?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!