LinkedList 클래스는 Java에서 일반적으로 사용되는 컬렉션 클래스 중 하나이며 이중 연결 목록 구조입니다. LinkedList 클래스는 추가, 삭제 및 기타 작업을 포함하여 연결된 목록을 작동하는 다양한 메서드를 제공합니다. 그 중, RemoveFirst() 메소드는 LinkedList 클래스에서 중요한 메소드이다. 이 기사에서는 이 방법의 기능을 분석하고 해당 코드 예제를 제공하여 독자가 이 방법의 사용을 더 잘 이해할 수 있도록 돕습니다.
removeFirst() 메소드는 연결된 리스트의 헤드에서 첫 번째 요소를 삭제하고 해당 요소의 값을 반환하는 데 사용됩니다. 연결된 목록이 비어 있으면 이 메서드는 NoSuchElementException을 발생시킵니다. 이 메소드의 자세한 정의는 다음과 같습니다.
public E removeFirst() { if (size == 0) throw new NoSuchElementException(); final Node<E> f = first; first = f.next; f.next = null; size--; return f.item; }
위 코드에서 볼 수 있듯이, RemoveFirst() 메소드의 구체적인 구현은 매우 간단합니다. 아래에서는 이 방법의 주요 기능을 단계별로 분석합니다.
(1) 연결 목록이 비어 있는지 확인
방법 시작 부분에서 if 문을 사용하여 연결 목록의 크기가 0인지 확인합니다. . 연결된 목록이 비어 있으면 NoSuchElementException이 발생하며 이는 RemoveFirst() 메서드의 첫 번째 단계입니다.
(2) 헤드 노드 저장
앞서 언급했듯이, RemoveFirst() 메소드의 주요 기능은 연결리스트의 헤드 노드를 삭제하는 것입니다. 따라서 연결리스트 삭제 작업을 수행하기 전에 첫 번째 노드를 저장해야 합니다.
(3) 헤드 노드의 포인팅 수정
연결 리스트의 헤드에서 첫 번째 요소를 삭제하려면 헤드 노드의 포인팅을 수정해야 합니다. 이 방법에서는 헤드 노드의 후속 노드를 헤드 노드에 할당합니다. 이런 방식으로 헤드 노드는 원래 연결 리스트의 두 번째 노드를 가리킵니다.
(4) 삭제된 노드의 참조 지우기
Java는 자동 가비지 수집 메커니즘을 채택하기 때문에 노드가 삭제된 후에도 자동 재활용 메커니즘에 의해 재활용되지 않은 메모리 부분이 여전히 남아 있습니다. 메모리의 일부가 메모리 공간을 차지합니다. 시간이 길면 재활용되지 않으면 메모리 누적이 발생하며 이 현상으로 인해 프로그램의 메모리 사용량이 너무 높아집니다. 따라서 이러한 상황이 발생하는 것을 방지하려면 삭제된 노드 참조를 메모리에서 삭제하여 해당 노드가 점유하고 있는 메모리를 해제해야 합니다.
(5) 연결 목록의 요소 수 수정
요소를 삭제한 후에는 그에 따라 연결 목록의 요소 수를 1씩 줄여야 합니다.
(6) 삭제된 요소의 값을 반환합니다
마지막으로 이 메서드는 삭제된 노드의 값을 반환합니다. 두 번째 단계에서 헤드 노드를 저장했기 때문에 저장된 헤드 노드를 직접 반환할 수 있습니다.
다음은 다음과 같은 주요 단계를 포함하는 RemoveFirst() 메소드를 사용하는 간단한 예입니다.
(1) LinkedList 객체를 생성하고 일부 요소를 추가합니다.
(2) 연결리스트의 첫 번째 요소를 삭제하려면 RemoveFirst() 메서드를 사용하세요. (3) 요소를 삭제한 후 연결리스트의 요소를 출력합니다.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); } }
Before remove first: [A, B, C] Deleted element: A After remove first: [B, C]
위 내용은 Java 문서 해석: LinkedList 클래스의 RemoveFirst() 메소드 함수 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!