Vector ist eine Unterklasse von AbstractList und Stack ist eine Unterklasse von Vector in der Java-API. Das Java Collections Framework wurde in Java 2 eingeführt. Zuvor wurden mehrere Datenstrukturen unterstützt, darunter die Klassen Vector und Stack. Diese Klassen wurden neu gestaltet, um in das Java Collections Framework zu passen, aber alle ihre alten Methoden werden für
beibehalten.
Kompatibilität.
Vector ist dasselbe wie ArrayList, außer dass es synchronisierte Methoden für den Zugriff auf und die Änderung des Vektors enthält. Synchronisierte Methoden können eine Datenbeschädigung verhindern, wenn zwei oder mehr Threads gleichzeitig auf einen Vektor zugreifen und ihn ändern. Für die vielen Anwendungen, die keine Synchronisierung erfordern, ist die Verwendung von ArrayList effizienter als die Verwendung von Vector.
Die Klasse Vector erweitert die Klasse AbstractList. Es verfügt außerdem über die Methoden, die in der ursprünglichen Klasse Vector enthalten sind, die vor Java 2 definiert wurde, wie in der Abbildung unten dargestellt.
Die meisten Methoden in der Klasse Vector, die im UML-Diagramm in der obigen Abbildung aufgeführt sind, ähneln den Methoden in der Schnittstelle List. Diese Methoden wurden vor dem Java Collections Framework eingeführt. Beispielsweise ist addElement(Object element) dasselbe wie die Methode add(Object element), außer dass die Methode addElement synchronisiert ist. Verwenden Sie die Klasse ArrayList, wenn Sie keine Synchronisierung benötigen. Es funktioniert viel schneller als Vector.
Die Methode elements() gibt eine Enumeration zurück. Die Schnittstelle Enumeration wurde vor Java 2 eingeführt und durch die Schnittstelle Iterator ersetzt. Vektor wird häufig in Java-Legacy-Code verwendet, da es sich vor Java 2 um die Java-Implementierung für veränderbare Arrays handelte.
Im Java Collections Framework wird Stack als Erweiterung von Vector implementiert, wie in der Abbildung unten dargestellt.
Die Klasse Stack wurde vor Java 2 eingeführt. Die in der Abbildung oben gezeigten Methoden wurden vor Java 2 verwendet. Die Methode empty() ist dieselbe wie isEmpty (). Die Methode peek() betrachtet das Element oben im Stapel, ohne es zu entfernen. Die Methode pop() entfernt das oberste Element vom Stapel und gibt es zurück. Die Methode push(Object element) fügt das angegebene Element zum Stapel hinzu. Die Methode search(Object element) prüft, ob sich das angegebene Element im Stapel befindet.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3