Heim >Java >javaLernprogramm >Fassen Sie mehrere häufig verwendete Datenstrukturen in Java zusammen und teilen Sie sie
Es gibt mehrere häufig verwendete Datenstrukturen in Java, die hauptsächlich in Sammlung und Karte unterteilt sind sind zwei Hauptschnittstellen (Schnittstellen stellen nur Methoden bereit, keine Implementierungen), und die letztendlich im Programm verwendeten Datenstrukturen sind von diesen Schnittstellen geerbte Datenstrukturklassen. Die Hauptbeziehungen (Vererbungsbeziehungen) sind: (----Weitere Informationen finden Sie in der Java-API-Dokumentation!)
Collection---->Collections SortedMap--- ---> ;TreeMap
Collection---->List----->(Vector ArryList LinkedList) ;HashMap
Collection---->Set------>(HashSet LinkedHashSet SortedSet)
API--- -Diese Klasse besteht ausschließlich aus statischen Methoden, die Sammlungen bearbeiten oder zurückgeben. Sie enthält polymorphe Algorithmen, die Sammlungen bearbeiten, „Wrapper“, die eine neue Sammlung zurückgeben, die von einer bestimmten Sammlung unterstützt wird, und einige andere Kleinigkeiten.
Die Methoden dieser Klasse lösen alle eine NullPointerException aus, wenn die ihnen bereitgestellten Sammlungen oder Klassenobjekte null sind
API----Diese Klasse besteht ausschließlich aus statischen Methoden, die Sammlungen bearbeiten oder zurückgeben. Sie enthält polymorphe Algorithmen, die Sammlungen bearbeiten, „Wrapper“, die eine neue Sammlung zurückgeben, die von einer bestimmten Sammlung unterstützt wird, und einige andere Vorteile und endet.
Die Methoden dieser Klasse lösen alle eine NullPointerException aus, wenn die ihnen bereitgestellten Sammlungen oder Klassenobjekte null sind.
Liste ist geordnete Sammlung. Verwenden Sie diese Schnittstelle, um die Einfügeposition jedes Elements genau zu steuern. Benutzer können den Index (die Position des Elements in der Liste, ähnlich dem Array-Index) verwenden, um auf die Elemente in der Liste zuzugreifen, was Java-Arrays ähnelt.
API---- Die Vector
-Klasse implementiert ein erweiterbares Array von Objekten. Sie enthält wie ein Array Komponenten, auf die über einen ganzzahligen Index zugegriffen werden kann. Die Größe eines Vector
kann jedoch nach Bedarf vergrößert oder verkleinert werden, um das Hinzufügen und Entfernen von Elementen zu ermöglichen
DasVector
wurde erstellt, daher ist es schwierig, die Einschränkungen von Arrays zu vermeiden, und gleichzeitig kann die Leistung Arrays nicht überschreiten. Deshalb sollten wir, wo möglich, mehr Arrays verwenden. Ein weiterer sehr wichtiger Punkt ist, dass Vector Thread-synchronisiert (synchronisiert) ist, weshalb Vector und ArrayList
ein wichtiger Unterschied.
4. ArrayList
List-Schnittstelle. Implementiert alle optionalen Listenoperationen und lässt alle Elemente zu, einschließlich null
. Zusätzlich zur Implementierung derVector, außer dass sie nicht synchronisiert ist.)
Wie Vector handelt es sich um eine verknüpfte Liste basierend auf einem Array, der Unterschied besteht jedoch darin, dass ArrayList nicht synchronisiert ist. Daher ist es in Bezug auf die Leistung besser als Vector, aber wenn es in einer Multithread-Umgebung ausgeführt wird, müssen Sie die Synchronisierung der Threads selbst verwalten.
API----Verknüpfte Listenimplementierung der List-Schnittstelle implementiert alle optionalen Listenoperationen und lässt alle Elemente zu (einschließlichnull). Zusätzlich zur Implementierung derList-Schnittstelle Die LinkedList-Klasse stellt einheitlich benannte Methoden zumAbrufen, Entfernen undEinfügen eines Elements am Anfang und Ende der Liste bereit. Diese Operationen ermöglichen verknüpfte Listen als Stapel, Warteschlange, oderdoppelendige Warteschlange.
LinkedList unterscheidet sich von den beiden vorherigen Listen dadurch, dass es nicht auf Arrays basiert und daher nicht durch die Array-Leistung eingeschränkt ist.
Jeder Knoten (Knoten) enthält zwei Aspekte des Inhalts:
1. Die Daten des Knotens selbst; Knoteninformationen (nextNode).
Wenn Sie also Aktionen zu LinkedList hinzufügen und löschen, ist es nicht erforderlich, viele Daten wie bei Array-basierten ArrayList zu verschieben. Dies kann durch einfaches Ändern der relevanten Informationen von nextNode erreicht werden. Dies ist der Vorteil von LinkedList.
6. Set (Schnittstelle) API-----Eine Sammlung, die keine doppelten Elemente enthält
undMengee1
Abstraktion e2
e1.equals(e2)
Menge ist eine Sammlung
API-----Diese Klasse implementiert die Set-Schnittstelle, unterstützt durch eine Hash-Tabelle (eigentlich eineHashMap-Instanz). Es gibt keine Garantien hinsichtlich der Iteration Die Reihenfolge der Menge ist insbesondere nicht gewährleistet, dass die Reihenfolge im Laufe der Zeit konstant bleibt. Obwohl Set und List beide die Collection-Schnittstelle implementieren, ist dies der Fall ganz anders. Die Liste basiert grundsätzlich auf Array. Aber Set wird auf Basis von HashMap implementiert. Dies ist der grundlegende Unterschied zwischen Set und List. Die Speichermethode von HashSet besteht darin, den Schlüssel in HashMap als entsprechendes Speicherelement von Set zu verwenden. schau mal Die Implementierung der Methode add(Object obj) von HashSet ist auf einen Blick ersichtlich.
8. LinkedHashSet
API----Verknüpfte Listenimplementierung der Liste
LinkedList einheitlich benannte Methoden um ein Element am Anfang und Ende der Liste zuabzurufen, zu entfernen undeinzufügen. Diese Operationen ermöglichen die Verwendung verknüpfter Listen als Stapel, Warteschlange usw. oderdoppelendige Warteschlange. Eine Unterklasse von HashSet, einer verknüpften Liste.
API---A
, das außerdem eineSet
Ordered Set, Comparator
wird durch SortedMap implementiert. SortedMap
Zusammenfassung festlegen:
Karte ist ein Schlüsselobjekt, das einem Container zugeordnet ist mit einem Wertobjekt, und ein Wertobjekt kann eine Karte usw. sein, wodurch eine mehrstufige Karte entsteht. Bei Schlüsselobjekten wie Set dürfen die Schlüsselobjekte in einem Map-Container nicht wiederholt werden. Dies dient dazu, die Konsistenz der Suchergebnisse zu gewährleisten. Wenn es zwei gleiche Schlüsselobjekte gibt, möchten Sie den Wert erhalten Objekt, das diesem Schlüsselobjekt entspricht. Möglicherweise ist das, was Sie erhalten, nicht der von Ihnen gedachte Wert, und das Ergebnis ist Verwirrung. Daher ist die Einzigartigkeit des Schlüssels sehr wichtig und entspricht der Natur das Set. Natürlich kann sich während der Verwendung das einem bestimmten Schlüssel entsprechende Wertobjekt ändern. In diesem Fall entspricht das zuletzt geänderte Wertobjekt dem Schlüssel. Es gibt keine Eindeutigkeitsanforderung für Wertobjekte. Sie können einem Wertobjekt problemlos eine beliebige Anzahl von Schlüsseln zuordnen (dies kann jedoch zu Unannehmlichkeiten bei Ihrer Verwendung führen. Sie wissen nicht, was Sie erhalten. Ist das entsprechende Wertobjekt?). Schlüssel). API----Hash-tabellenbasierte Implementierung derMap-Schnittstelle. Diese Implementierung stellt alle optionalen Kartenoperationen bereit und erlaubtnull
Werte und der Schlüssel null (Die Klasse HashMap entspricht in etwa der Klasse Hashtable, außer dass sie unsynchronisiert ist und Nullen zulässt.) Diese Klasse macht keine Garantien insbesondere hinsichtlich der Reihenfolge der Karte;
Die Reihenfolge bleibt im Laufe der Zeit konstant. API----Eine auf einem Rot-Schwarz-Baum basierende TreeMap speichert Schlüssel in der richtigen Reihenfolge. Es verfügt über einige erweiterte Methoden wie firstKey(), lastKey() usw. Sie können auch einen Bereich von TreeMap angeben, um dessen Unterkarte zu erhalten. ------------Beschreibung---------- 1. Unterschiede zwischen mehreren häufig verwendeten Kategorien -------------Karte----------------
1. HashMap
2. TreeMap
NavigableMap
-Implementierung .Die Karte ist sortiert nach
abhängig vom verwendeten Konstruktor Comparator
Die Zuordnung zwischen Schlüsseln und Werten ist sehr einfach. Verwenden Sie die Methode put(Object key, Object value), um einen Schlüssel einem Wertobjekt zuzuordnen. Verwenden Sie get(Object key), um das diesem Schlüsselobjekt entsprechende Wertobjekt abzurufen.
1. ArrayList:
Einzelnes Element, hohe Effizienz, wird hauptsächlich für Abfragen verwendet
2. Vektor:
Einzelnes Element, Thread-sicher, wird hauptsächlich für Abfragen verwendet
3. LinkedList: Einzelnes Element, das hauptsächlich zum Einfügen und Löschen verwendet wird
4. HashMap:
Die Elemente sind paarweise und die Elemente können leer sein
5. HashTable:
Elemente sind gepaart, threadsicher und Elemente können nicht null sein 2. Vector, ArrayList und LinkedList
In den meisten Fällen ArrayList ist in Bezug auf die Leistung am besten, aber wenn es um Sammlungen geht, bietet LinkedList eine bessere Leistung, wenn die darin enthaltenen Elemente häufig eingefügt und gelöscht werden müssen, aber die Leistung der drei ist nicht so gut wie die von Arrays. Darüber hinaus ist Vector threadsynchronisiert. Also:
Wenn Sie ein Array verwenden können (Elementtyp ist fest, Array-Länge ist fest), versuchen Sie bitte, ein Array anstelle von List zu verwenden ;
Wenn es keine häufigen Lösch- und Einfügevorgänge gibt und keine Notwendigkeit besteht, Multithreading-Probleme zu berücksichtigen, wird ArrayList bevorzugt
Wenn Sie häufig löschen und einfügen müssen, ist LinkedList praktisch.
Wenn Sie nichts wissen, ist die Verwendung nicht verkehrt ArrayList.
3. Sammlungen und Arrays
in
Es gibt zwei Klassen im Java-Collection-Klassen-Framework namens Collections (Achtung, nicht Collection!) und Arrays. Dies sind leistungsstarke Tools in JCF, die Anfänger jedoch häufig ignorieren. Laut JCF-Dokument stellen diese beiden Klassen Wrapper-Implementierungen (Wrapper-Implementierungen), Datenstrukturalgorithmen und Array-bezogene Anwendungen bereit.
Ich bin sicher, dass Sie die oben erwähnten klassischen Algorithmen wie „Halbsuche“ und „Sortieren“ nicht vergessen werden von statischen Methoden helfen uns, diese lästigen Aufgaben in Datenstrukturklassen einfach zu erledigen:
binarySearch: binäre Suche.
sortieren: Sortieren, hier ist eine Methode ähnlich der schnellen Sortierung, die Effizienz ist immer noch ist O(n
* log n), ist aber eine stabile Sortiermethode. umgekehrt: Betreiben Sie eine lineare Tabelle in umgekehrter Reihenfolge. Dies ist eine klassische Frage zur Datenstruktur in der Vergangenheit!
drehen: „Rotieren“ Sie den linearen Tisch um ein bestimmtes Element als Achse.
Swap: Vertauschen Sie die Positionen zweier Elemente in einer linearen Liste.
…
Sammlungen haben auch eine wichtige Funktion ist der „Wrapper“, der einige Methoden zum Konvertieren einer Sammlung in eine spezielle Sammlung bereitstellt, wie folgt:
unmodifiableXXX: In eine schreibgeschützte Sammlung konvertieren, wobei XXX sechs grundlegende Sammlungsschnittstellen darstellt: Collection, List, Map, Set, SortedMap und SortedSet. Wenn Sie eine schreibgeschützte Sammlung einfügen oder löschen, wird eine UnsupportedOperationException ausgelöst.
synchronizedXXX: In synchronisierte Sammlung konvertieren.
Singleton: Erstellen Sie eine Sammlung mit nur einem Element. Hier generiert Singleton einen einzelnen Elementsatz ,
singletonList und singletonMap generieren jeweils eine Einzelelementliste und -karte.
Leerer Satz: dargestellt durch die statischen Eigenschaften EMPTY_SET, EMPTY_LIST und EMPTY_MAP der Sammlungen.
Das obige ist der detaillierte Inhalt vonFassen Sie mehrere häufig verwendete Datenstrukturen in Java zusammen und teilen Sie sie. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!