목차
1. PriorityQueue 사용 시 주의 사항
PriorityQueue
2. PriorityQueue의 요소 비교
Java java지도 시간 Java 컬렉션 프레임워크의 PriorityQueue 우선순위 큐

Java 컬렉션 프레임워크의 PriorityQueue 우선순위 큐

Jun 09, 2022 am 11:47 AM
java

이 기사에서는 PriorityQueue 우선 순위 대기열에 대한 관련 지식을 주로 소개하는 java에 대한 관련 지식을 제공합니다. Java 컬렉션 프레임워크는 PriorityQueue 및 PriorityBlockingQueue라는 두 가지 유형의 우선 순위 대기열을 제공합니다. PriorityBlockingQueue는 스레드입니다. -안전합니다. 모두에게 도움이 되기를 바랍니다.

Java 컬렉션 프레임워크의 PriorityQueue 우선순위 큐

추천 학습: "java 비디오 튜토리얼"

Java 수집 프레임워크는 PriorityQueue 및 PriorityBlockingQueue라는 두 가지 유형의 우선순위 대기열을 제공합니다. PriorityQueue는 스레드에 안전하지 않으며 PriorityBlockingQueue는 주로 스레드에 안전합니다. PriorityQueue

Java 컬렉션 프레임워크에서 PriorityQueue의 관계는 다음과 같습니다.

1. PriorityQueue 사용 시 주의 사항

1. 사용 시 PriorityQueue가 있는 패키지를 가져와야 합니다.

import java.util.PriorityQueue

2. 크기를 비교할 수 없는 개체는 크기가 비슷해야 합니다. 그렇지 않으면
ClassCastException이 발생합니다.
3. Null 개체는 삽입할 수 없습니다. 그렇지 않으면 NullPointerException이 발생합니다.

4. 용량 제한이 없으며 요소 수에 관계없이 삽입할 수 있으며 내부 용량은 자동으로 확장될 수 있습니다

5. 요소 삽입 및 삭제는 기본 2

6의 로그 n입니다. PriorityQueue의 기본 사용 힙 데이터 구조

7. PriorityQueue는 기본적으로 작은 힙입니다. 즉, 매번 얻는 요소가 가장 작습니다. 요소 (

큰 힙을 만들고 싶다면 메소드를 다시 비교해야 합니다. 기본 비교 메소드는 Comparable 인터페이스의 CompareTo 메소드입니다.)

2. PriorityQueue의 공통 인터페이스 소개

1. queue

다음은

PriorityQueue

에 있는 몇 가지 일반적인 구성 방법입니다. 다른 문서의 도움말을 참조할 수 있습니다. ㅋㅋㅋ

초기 A 우선순위 만들기 참고:

initialCapacity는 1보다 작을 수 없습니다. 그렇지 않으면 IllegalArgumentException이 발생합니다 Often컬렉션을 사용하여 생성 우선 순위 대기열 기본 초기 용량이 지정된 비교기 초기 용량이 <td>initialCapacity<br> </td>인 <td>우선순위 대기열을 생성합니다. , </td>
PriorityQueue(Collection 확장 E> c)
PriorityQueue(Comparator<? super E> 비교기)
기본 초기 용량인 우선 순위 대기열
을 생성하고
를 기준으로 해당 요소를 평가합니다. PriorityQueue(intinitialCapacity, Comparator <? super E> comparator)
에 의해 지정된 비교기 에 따라 요소를 비교합니다. 참고: PriorityQueue(Comparator<? super E> comparator) 创建具有默认初始容量的优先级队列,并根据指定的比较器对其元素进行比较
PriorityQueue(int initialCapacity, Comparator <? super E> comparator)

创建一个初始容量为<strong>initialCapacity</strong>的优先级队列initialCapacity는 1보다 작을 수 없습니다. 그렇지 않으면 IllegalArgumentException이 발생합니다보통

2. PriorityQueue의 요소 비교

구성 방법을 읽은 후 다시 질문에 대해 생각해 봅시다

우선 순위 큐는 어떻게 순서를 달성합니까? 우선순위 큐는 작은 루트 힙의 도움으로 구현되기 때문에

작은 루트 힙을 구현하는 과정에서 요소 비교가 발생해야 한다는 것을 알고 있으므로 PriorityQueue의 요소는 크기를 비교할 수 있어야 합니다. , 그렇다면 PriorityQueue는 요소를 어떻게 수행합니까? 비교는 어떻습니까?

PriorityQueue는
Comparble과 Comparator의 두 가지 방법을 채택합니다.

1. Comparble은 기본 내부 비교 방법입니다. . 사용자가 사용자 정의 유형 개체를 삽입하는 경우 개체는 Comparble 인터페이스를 구현하고 CompareTo 메서드를 재정의해야 합니다.

2 사용자는 비교 Comparator를 사용하도록 선택할 수도 있습니다. 객체에서 사용자가 사용자 정의 유형 객체를 삽입하는 경우 비교기 클래스를 제공해야 하며 클래스가 Comparator 인터페이스를 구현하고 비교 메서드를 재정의하도록 해야 합니다.

여기서 프로그램이 오류를 보고한 것을 확인했습니다. 이유는 무엇입니까? 우리가 삽입한 Child 객체는 비교할 수 없기 때문에(

즉, Comparable 인터페이스를 구현하지 않고 사용자 정의 비교기를 사용하지 않습니다)

볼 수 있습니다. 즉, 기본 비교 방법을 사용합니다 Comparable 인터페이스의 CompareTo 메소드

이번에 오류 메시지를 다시 살펴보겠습니다

PriorityQueue에 요소를 삽입할 때 문제가 있는 것 같습니다

그럼 열어보겠습니다. PriorityQueue 소스코드를 살펴보세요(

아래) PriorityQueue의 Offer 메소드 소스코드입니다

shiftUp 소스코드를 다시 살펴보세요

계속해서 siftUpComparable을 클릭하세요

이번에는 PriorityQueue에 넣은 Child 객체를 다시 살펴보겠습니다.

맞춤형 비교기도 없고 Comparable 인터페이스도 구현하지 않았으며물론 오류가 발생합니다!

그럼 Child 클래스에 Comparable 인터페이스를 구현하고 연령별로 비교해 보겠습니다

import java.util.PriorityQueue;
class Child implements Comparable<Child>{
    int age;
    String name;

    public Child(int age, String name) {
        this.age = age;
        this.name = name;
    }

    @Override
    public int compareTo(Child o) {
        return this.age - o.age;  // 默认实现小根堆
    }

    @Override
    public String toString() {
        return "Child{" +
                "age=" + age +
                ", name='" + name + '\'' +
                '}';
    }
}
public class TestPriorityQueue {
    public static void main(String[] args) {
        PriorityQueue<Child> priorityQueue = new PriorityQueue<>();

        priorityQueue.offer(new Child(12, "小亮"));
        priorityQueue.offer(new Child(11, "小红"));
        priorityQueue.offer(new Child(8, "小强"));
        System.out.println(priorityQueue);
    }
}
로그인 후 복사

큰 루트 힙을 구현하고 싶다면 쉽습니다

Compable을 구현했습니다. 위의 인터페이스를 사용한다면 연령 비교기를 사용자 정의하는 것은 어떨까요?

class Child {
    int age;
    String name;

    public Child(int age, String name) {
        this.age = age;
        this.name = name;
    }

    @Override
    public String toString() {
        return "Child{" +
                "age=" + age +
                ", name='" + name + '\'' +
                '}';
    }
}
class AgeComparator implements Comparator<Child> {

    @Override
    public int compare(Child o1, Child o2) {
        return o1.age - o2.age; // 实现小根堆
        // return o2.ae - o1.age 实现大根堆
    }
}
public class TestPriorityQueue {
    public static void main(String[] args) {
        AgeComparator ageComparator = new AgeComparator();
        // 创建具有默认初始容量的 PriorityQueue ,并根据指定的比较器对其元素进行排序。
        PriorityQueue<Child> priorityQueue = new PriorityQueue<>(ageComparator);
        // 可以看到这里我的Child对象虽然没有实现Comparable接口,但因为我们对Child对象自定义了一个年龄比较器,所以插入元素不会报错
        priorityQueue.offer(new Child(12, "小亮"));
        priorityQueue.offer(new Child(11, "小红"));
        priorityQueue.offer(new Child(8, "小强"));
        System.out.println(priorityQueue);
    }
}
로그인 후 복사

3. 우선순위가 가장 높은 요소 삽입/삭제/가져오기

함수 이름함수 소개boolean요소 삽입 e, 성공적으로 삽입했습니다. e 객체가 비어 있으면 NullPointerException이 발생합니다. 참고: 공간이 충분하지 않으면 E peek()E poll()int size() Levoidar Clear () Clear Boolean Isemty () 를 반환합니다. 권장 학습: "》
offer(E e)

가장 높은 요소를 가져옵니다. 우선 순위 큐가 비어 있으면 null을 반환
우선 순위가 가장 높은 요소를 제거하고 반환하고, 우선 순위 큐가 비어 있으면 null을 반환
가져옵니다. 유효한 요소 수

우선 순위 큐가 비어 있는지 감지하여 True

java 비디오 튜토리얼

위 내용은 Java 컬렉션 프레임워크의 PriorityQueue 우선순위 큐의 상세 내용입니다. 자세한 내용은 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를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

자바의 제곱근 자바의 제곱근 Aug 30, 2024 pm 04:26 PM

자바의 제곱근 안내 여기서는 예제와 코드 구현을 통해 Java에서 Square Root가 어떻게 작동하는지 설명합니다.

자바의 완전수 자바의 완전수 Aug 30, 2024 pm 04:28 PM

Java의 완전수 가이드. 여기서는 정의, Java에서 완전 숫자를 확인하는 방법, 코드 구현 예제에 대해 논의합니다.

Java의 난수 생성기 Java의 난수 생성기 Aug 30, 2024 pm 04:27 PM

Java의 난수 생성기 안내. 여기서는 예제를 통해 Java의 함수와 예제를 통해 두 가지 다른 생성기에 대해 설명합니다.

자바의 웨카 자바의 웨카 Aug 30, 2024 pm 04:28 PM

Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 스미스 번호 Java의 스미스 번호 Aug 30, 2024 pm 04:28 PM

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

Java Spring 인터뷰 질문 Java Spring 인터뷰 질문 Aug 30, 2024 pm 04:29 PM

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8 Stream foreach에서 나누거나 돌아 오시겠습니까? Java 8 Stream foreach에서 나누거나 돌아 오시겠습니까? Feb 07, 2025 pm 12:09 PM

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 날짜까지의 타임스탬프 Java의 날짜까지의 타임스탬프 Aug 30, 2024 pm 04:28 PM

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

See all articles