Die LinkedList-Klasse ist eine der am häufigsten verwendeten Sammlungsklassen in Java. Es handelt sich um eine doppelt verknüpfte Listenstruktur. Die LinkedList-Klasse bietet viele Methoden zum Betreiben verknüpfter Listen, einschließlich Hinzufügung, Löschung und anderer Vorgänge. Unter diesen ist die Methode „removeFirst()“ eine wichtige Methode in der LinkedList-Klasse. In diesem Artikel werden die Funktionen dieser Methode analysiert und entsprechende Codebeispiele bereitgestellt, um den Lesern ein besseres Verständnis der Verwendung dieser Methode zu erleichtern.
Die Methode „removeFirst()“ wird verwendet, um das erste Element aus dem Kopf der verknüpften Liste zu löschen und den Wert des Elements zurückzugeben. Wenn die verknüpfte Liste leer ist, löst diese Methode eine NoSuchElementException aus. Die detaillierte Definition dieser Methode lautet wie folgt:
public E removeFirst() { if (size == 0) throw new NoSuchElementException(); final Node<E> f = first; first = f.next; f.next = null; size--; return f.item; }
Wie aus dem obigen Code ersichtlich ist, ist die spezifische Implementierung der Methode „removeFirst()“ sehr einfach. Im Folgenden analysieren wir Schritt für Schritt die Hauptfunktionen dieser Methode:
(1) Bestimmen Sie, ob die verknüpfte Liste leer ist.
Bestimmen Sie zu Beginn der Methode mit der if-Anweisung, ob die Größe der verknüpften Liste 0 ist . Wenn die verknüpfte Liste leer ist, wird eine NoSuchElementException ausgelöst. Dies ist der erste Schritt der Methode „removeFirst()“.
(2) Speichern Sie den Kopfknoten
Wie bereits erwähnt, besteht die Hauptfunktion der Methode „removeFirst()“ darin, den Kopfknoten der verknüpften Liste zu löschen. Daher muss der erste Knoten gespeichert werden, bevor der Löschvorgang für die verknüpfte Liste ausgeführt wird.
(3) Ändern Sie die Ausrichtung des Kopfknotens
Um das erste Element aus dem Kopf der verknüpften Liste zu löschen, muss die Ausrichtung des Kopfknotens geändert werden. Bei dieser Methode weisen wir dem Kopfknoten die Nachfolgeknoten des Kopfknotens zu. Auf diese Weise zeigt der Kopfknoten auf den zweiten Knoten in der ursprünglichen verknüpften Liste.
(4) Löschen Sie die Referenzen gelöschter Knoten
Da Java einen automatischen Garbage-Collection-Mechanismus verwendet, gibt es nach dem Löschen des Knotens immer noch einen Teil des Speichers, der nicht vom automatischen Recyclingmechanismus recycelt wurde Der Speicher belegt den Speicherplatz. Wenn die Zeit nicht recycelt wird, kommt es zu einer Speicherakkumulation, und dieses Phänomen führt zu einer zu hohen Speichernutzung des Programms. Um diese Situation zu vermeiden, muss daher die gelöschte Knotenreferenz aus dem Speicher gelöscht werden, um den vom Knoten belegten Speicher freizugeben.
(5) Ändern Sie die Anzahl der Elemente in der verknüpften Liste
Nach dem Löschen eines Elements muss die Anzahl der Elemente in der verknüpften Liste entsprechend um 1 reduziert werden.
(6) Gibt den Wert des gelöschten Elements zurück
Schließlich gibt diese Methode den Wert des gelöschten Knotens zurück. Da wir im zweiten Schritt den Kopfknoten gespeichert haben, können wir den gespeicherten Kopfknoten direkt zurückgeben.
Das Folgende ist ein einfaches Beispiel für die Verwendung der Methode „removeFirst()“, das die folgenden Hauptschritte enthält:
(1) Erstellen Sie ein LinkedList-Objekt und fügen Sie einige Elemente hinzu; (2) Verwenden Sie die Methode „removeFirst()“, um das erste Element der verknüpften Liste zu löschen.
(3) Geben Sie die Elemente der verknüpften Liste aus, nachdem Sie das Element gelöscht haben.
import java.util.LinkedList; public class RemoveFirstTest { public static void main(String[] args) { LinkedList<String> list = new LinkedList<>(); list.add("A"); list.add("B"); list.add("C"); System.out.println("Before remove first: " + list); String first = list.removeFirst(); System.out.println("Deleted element: " + first); System.out.println("After remove first: " + list); } }
Führen Sie den obigen Code aus und die Ausgabe sieht wie folgt aus:
Before remove first: [A, B, C] Deleted element: A After remove first: [B, C]
Wie aus der Ausgabe ersichtlich ist, löscht diese Methode erfolgreich das erste Element der verknüpften Liste und gibt den Wert des Elements korrekt zurück.
FazitDas obige ist der detaillierte Inhalt vonInterpretation der Java-Dokumentation: Funktionsanalyse der Methode „removeFirst()' der Klasse „LinkedList'.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!