Der Unterschied zwischen Liste und Arraylist in Java
Nov 18, 2019 pm 01:17 PMUnterschied:
List ist eine Schnittstelle und ArrayList ist eine Implementierungsklasse der List-Schnittstelle. Die ArrayList-Klasse erbt und implementiert die List-Schnittstelle.
Daher kann die List-Schnittstelle nicht erstellt werden, das hei?t, wir k?nnen keine Instanzobjekte erstellen, aber wir k?nnen für die List-Schnittstelle wie folgt eine Objektreferenz erstellen, die auf uns selbst verweist, und das Instanzobjekt der ArrayList Die Implementierungsklasse ist Dies fungiert als Objektreferenz auf die List-Schnittstelle.
Animals.java public abstract class Animals { //動物名字 String name; //動物叫聲 public void shout(){ System.out.println("叫聲----"); } } Dog.java public class Dog extends Animals { //狗類獨(dú)有的方法 public void guard(){ System.out.println("狗獨(dú)有的看門本領(lǐng)"); } } Test.java public class Test { public static void main(String[] args) throws ClassNotFoundException { Animals a1 = new Animals(); Animals a2 = new Dog(); } }
List list;//正確,list = null; List list = new List();//是錯(cuò)誤的用法
List list = new ArrayList();
Dieser Satz erstellt ein Objekt der ArrayList-Implementierungsklasse und verfolgt es bis zur List-Schnittstelle. Zu diesem Zeitpunkt handelt es sich um ein List-Objekt. Es verfügt über einige Eigenschaften und Methoden, über die die ArrayList-Klasse verfügt. Es kann jedoch kein Objekt mehr verwendet werden beh?lt alle Eigenschaften der ArrayList und Methoden bei.
ArrayList list=newArrayList();
Die übergeordnete Klasse kann keine Methoden mehr aufrufen, die in der übergeordneten Klasse, aber nicht in der untergeordneten Klasse vorkommen. Andernfalls kommt es zu Kompilierungsfehlern.
Wenn es so aussieht:
Test.java public class Test { public static void main(String[] args) throws ClassNotFoundException { Animals a2 = new Dog(); a2.shout(); a2.guard(); } }
Dann hat a alle Eigenschaften und Methoden von List und verfügt nicht über die eindeutigen Eigenschaften und Methoden seiner Implementierungsklasse ArrayList.
Wenn List und ArrayList dieselben Attribute (z. B. int i) und dieselbe Methode (z. B. void f()) haben,
dann ruft a.i i und a.f in List() auf f() in ArrayList;
Der Schlüssel zum Problem:Warum sollten wir
anstelle von verwenden? List list = new ArrayList()?
ArrayList alist = new ArrayList()
Das Problem besteht darin, dass die List-Schnittstelle mehrere Implementierungsklassen hat. Jetzt verwenden Sie ArrayList. Vielleicht müssen Sie eines Tages zu anderen Implementierungsklassen wechseln, wie zum Beispiel:
LinkedList oder Vector usw . Zu diesem Zeitpunkt müssen Sie nur diese Zeile ?ndern:
Andere Codes, in denen die Liste verwendet wird, müssen überhaupt nicht ge?ndert werden.?List list = new LinkedList();
Angenommen, Sie beginnen mit der Verwendung von
ArrayList alist = new ArrayList()
Empfohlenes Tutorial:
Das obige ist der detaillierte Inhalt vonDer Unterschied zwischen Liste und Arraylist in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Um JDBC -Transaktionen korrekt zu verarbeiten, müssen Sie zun?chst den automatischen Komiti -Modus ausschalten und dann mehrere Vorg?nge ausführen und schlie?lich entsprechend den Ergebnissen festlegen oder rollen. 1. Nennen Sie Conn.SetAutoCommit (False), um die Transaktion zu starten. 2. Führen Sie mehrere SQL -Operationen aus, z. B. einfügen und aktualisieren. 3. Rufen Sie Conn.Commit () an, wenn alle Vorg?nge erfolgreich sind, und rufen Sie Conn.Rollback () auf, wenn eine Ausnahme auftritt, um die Datenkonsistenz zu gew?hrleisten. Gleichzeitig sollten Try-with-Ressourcen verwendet werden, um Ressourcen zu verwalten, Ausnahmen ordnungsgem?? zu behandeln und Verbindungen zu schlie?en, um Verbindungsleckage zu vermeiden. Darüber hinaus wird empfohlen, Verbindungspools zu verwenden und Save -Punkte zu setzen, um teilweise Rollback zu erreichen und Transaktionen so kurz wie m?glich zu halten, um die Leistung zu verbessern.

Pre-Formancetartuptimemoryusage, QuarkusandmicronautleadduToCompile-Time-foringandgraalvSupport, WithQuarkusofttenperformLightBetterin serverloser Szenarien.2. Thyvelopecosystem,

Die Müllsammlung von Java (GC) ist ein Mechanismus, der automatisch den Speicher verwaltet, der das Risiko eines Speicherlecks verringert, indem unerreichbare Objekte zurückgeführt werden. 1.GC beurteilt die Zug?nglichkeit des Objekts aus dem Stammobjekt (z. B. Stapelvariablen, aktive Threads, statische Felder usw.) und nicht erreichbare Objekte als Müll markiert. 2. Basierend auf dem markierten Algorithmus markieren Sie alle erreichbaren Objekte und l?schen Sie nicht markierte Objekte. 3.. Verfolgen Sie eine Generationskollektionsstrategie: Die neue Generation (Eden, S0, S1) führt h?ufig MollGC aus; Die ?lteren Menschen erzielen weniger, dauert jedoch l?nger, um MajorGC durchzuführen. MetaPace speichert Klassenmetadaten. 4. JVM bietet eine Vielzahl von GC -Ger?ten: SerialGC ist für kleine Anwendungen geeignet; ParallelgC verbessert den Durchsatz; CMS reduziert sich

Durch die Auswahl des richtigen HTMlinput -Typs kann die Datengenauigkeit verbessert, die Benutzererfahrung verbessert und die Benutzerfreundlichkeit verbessert werden. 1. W?hlen Sie die entsprechenden Eingabetypen gem?? dem Datentyp aus, z. B. Text, E -Mail, Tel, Nummer und Datum, die automatisch überprüft und an die Tastatur anpassen k?nnen. 2. Verwenden Sie HTML5, um neue Typen wie URL, Farbe, Reichweite und Suche hinzuzufügen, die eine intuitivere Interaktionsmethode bieten k?nnen. 3.. Verwenden Sie Platzhalter und erforderliche Attribute, um die Effizienz und Genauigkeit der Formulierung zu verbessern. Es sollte jedoch beachtet werden, dass der Platzhalter das Etikett nicht ersetzen kann.

HTTP-Protokoll Middleware in Go kann Anforderungsmethoden, Pfade, Client-IP und zeitaufw?ndiges Aufzeichnen aufzeichnen. 1. Verwenden Sie http.Handlerfunc, um den Prozessor zu wickeln, 2. Nehmen Sie die Startzeit und die Endzeit vor und nach dem Aufrufen als n?chstes auf. Der vollst?ndige Beispielcode wurde überprüft, um auszuführen und eignet sich zum Starten eines kleinen und mittelgro?en Projekts. Zu den Erweiterungsvorschl?gen geh?ren das Erfassen von Statuscodes, die Unterstützung von JSON -Protokollen und die Nachverfolgung von ID -IDs.

GradleStheBetterChoiceFormostnewProjectsDuetoitSuperiorFlexibilit?t, Leistung und ModerntoolingSupport.1.GRADLE'SGROOVY/KOTLINDSLISMORECONCISEANDEIPRESSIVETHANMANMANBOSEXML.2.GRAGRECONCISEANDEPRPRESSIVETHANMAVENSVOSEXML.2.

Die klare Antwort auf diese Frage ist die Empfehlung, das Beobachtermuster mithilfe einer benutzerdefinierten Observer -Schnittstelle zu implementieren. 1. Obwohl Java beobachtbar und Beobachter liefert, ist erstere eine Klasse und wurde veraltet und fehlt Flexibilit?t. 2. Die moderne empfohlene Praxis besteht darin, eine funktionale Observer -Schnittstelle zu definieren, und das Subjekt beh?lt die Beobachterliste bei und benachrichtigt alle Beobachter, wenn sich der Zustand ?ndert. 3.. Es kann in Kombination mit Lambda -Ausdrücken verwendet werden, um die Einfachheit und Wartbarkeit des Codes zu verbessern. V. Daher sollten neue Projekte ein benutzerdefiniertes Observer-Schnittstellenschema annehmen, das Typen ist, einfach zu testen und sich auf moderne Java spezialisiert zu haben

Der ExecutorService eignet sich zur asynchronen Ausführung unabh?ngiger Aufgaben wie E/A -Operationen oder Zeitaufgaben, verwendete den Thread -Pool zur Verwaltung von Parallelit?t, sendete Runnable- oder Callable -Aufgaben über Senden und erzielte Ergebnisse mit Zukunft. Achten Sie auf das Risiko unbegrenzter Warteschlangen und schlie?en Sie den Fadenpool ausdrücklich; 2. Das Fork/Join-Framework ist für CPU-intensive Aufgaben von Split-Gouvernance-Aufgaben ausgelegt, basierend auf der Verteilung und kontroversen Methoden und Work-Stellungsalgorithmen und realisiert rekursive Aufteilung von Aufgaben durch Recursivetask oder Recursiveaction, die durch Forkjoinpool geplant und ausgeführt wird. Es eignet sich für gro?e Array -Summierungs- und Sortierszenarien. Der Split -Schwellenwert sollte vernünftigerweise eingestellt werden, um Overhead zu vermeiden. 3.. Auswahlbasis: unabh?ngig
