찾다
Javajava지도 시간Java 문서 해석: LinkedList 클래스의 RemoveFirst() 메소드 함수 분석

Java 문서 해석: LinkedList 클래스의 RemoveFirst() 메소드 함수 분석

Nov 03, 2023 pm 03:13 PM
자바 문서 해석링크리스트 클래스제거첫번째() 메서드

Java 문서 해석: LinkedList 클래스의 RemoveFirst() 메소드 함수 분석

LinkedList 클래스는 Java에서 일반적으로 사용되는 컬렉션 클래스 중 하나이며 이중 연결 목록 구조입니다. LinkedList 클래스는 추가, 삭제 및 기타 작업을 포함하여 연결된 목록을 작동하는 다양한 메서드를 제공합니다. 그 중, RemoveFirst() 메소드는 LinkedList 클래스에서 중요한 메소드이다. 이 기사에서는 이 방법의 기능을 분석하고 해당 코드 예제를 제공하여 독자가 이 방법의 사용을 더 잘 이해할 수 있도록 돕습니다.

  1. removeFirst() 메소드 설명

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;
}
  1. removeFirst() 메소드의 기능 분석

위 코드에서 볼 수 있듯이, RemoveFirst() 메소드의 구체적인 구현은 매우 간단합니다. 아래에서는 이 방법의 주요 기능을 단계별로 분석합니다.

(1) 연결 목록이 비어 있는지 확인

방법 시작 부분에서 if 문을 사용하여 연결 목록의 크기가 0인지 확인합니다. . 연결된 목록이 비어 있으면 NoSuchElementException이 발생하며 이는 RemoveFirst() 메서드의 첫 번째 단계입니다.

(2) 헤드 노드 저장

앞서 언급했듯이, RemoveFirst() 메소드의 주요 기능은 연결리스트의 헤드 노드를 삭제하는 것입니다. 따라서 연결리스트 삭제 작업을 수행하기 전에 첫 번째 노드를 저장해야 합니다.

(3) 헤드 노드의 포인팅 수정

연결 리스트의 헤드에서 첫 번째 요소를 삭제하려면 헤드 노드의 포인팅을 수정해야 합니다. 이 방법에서는 헤드 노드의 후속 노드를 헤드 노드에 할당합니다. 이런 방식으로 헤드 노드는 원래 연결 리스트의 두 번째 노드를 가리킵니다.

(4) 삭제된 노드의 참조 지우기

Java는 자동 가비지 수집 메커니즘을 채택하기 때문에 노드가 삭제된 후에도 자동 재활용 메커니즘에 의해 재활용되지 않은 메모리 부분이 여전히 남아 있습니다. 메모리의 일부가 메모리 공간을 차지합니다. 시간이 길면 재활용되지 않으면 메모리 누적이 발생하며 이 현상으로 인해 프로그램의 메모리 사용량이 너무 높아집니다. 따라서 이러한 상황이 발생하는 것을 방지하려면 삭제된 노드 참조를 메모리에서 삭제하여 해당 노드가 점유하고 있는 메모리를 해제해야 합니다.

(5) 연결 목록의 요소 수 수정

요소를 삭제한 후에는 그에 따라 연결 목록의 요소 수를 1씩 줄여야 합니다.

(6) 삭제된 요소의 값을 반환합니다

마지막으로 이 메서드는 삭제된 노드의 값을 반환합니다. 두 번째 단계에서 헤드 노드를 저장했기 때문에 저장된 헤드 노드를 직접 반환할 수 있습니다.

  1. removeFirst() 메소드의 코드 예

다음은 다음과 같은 주요 단계를 포함하는 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]

출력에서 볼 수 있듯이 이 메서드는 연결된 목록의 첫 번째 요소를 성공적으로 삭제하고 해당 요소의 값을 올바르게 반환합니다.

    결론
LinkedList 클래스는 Java에서 일반적으로 사용되는 컬렉션 클래스 중 하나이며, RemoveFirst() 메서드는 중요한 메서드 중 하나입니다. 이 기사에서는 이 메서드의 내부 기능을 분석하고 해당 코드 예제를 제공하여 독자가 이 메서드의 사용을 더 잘 이해할 수 있도록 돕습니다. 이 글이 당신에게 도움이 되기를 바랍니다.

위 내용은 Java 문서 해석: LinkedList 클래스의 RemoveFirst() 메소드 함수 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.