Java PriorityQueues에서 우선순위 업데이트
객체 순서 지정을 위해 Comparator와 함께 PriorityQueue를 활용하는 경우 객체의 클래스 변수에 대한 후속 변경 사항(다음에 따라) 어떤 우선순위가 계산되는지) 문제가 발생합니다.
전통적으로 간단한 해결 방법은 객체를 제거하고 해당 값을 업데이트한 후 다시 삽입하여 우선순위 큐의 비교기를 트리거하는 것입니다. 그러나 PriorityQueue 주위에 래퍼 클래스를 만드는 것보다 더 효율적인 대안이 있습니까?
답변
불행히도 제거하고 다시 삽입하는 것이 가장 효과적인 접근 방식으로 남아 있습니다. PriorityQueues는 본질적으로 삽입 시 적절한 위치에 새 요소를 삽입하여 대기열 성능을 최적화합니다. 대기열 제거 작업 중에 우선순위가 가장 높은 요소를 검색하면 성능에 큰 영향을 미칠 수 있습니다.
TreeMap은 HashMap(요소 해시 코드가 변경되면 실패함)과 함께 이 제한 사항을 공유합니다.
래퍼 클래스를 생성하려면 다음이 필요할 수 있습니다. 비교 코드를 대기열에 추가에서 제거로 이동하여 대기열에 추가하는 동안 정렬할 필요가 없습니다. 그러나 이 접근 방식은 성능을 저하시키며 우선순위 업데이트 시 동기화가 필요합니다. 어느 쪽이든 동기화가 필요하므로 대기열에서 제거 및 다시 대기열에 추가하는 것이 더 간단하고 성능이 뛰어난 솔루션을 제공합니다.
위 내용은 ## 제거하고 다시 삽입하지 않고도 Java PriorityQueue의 우선순위를 업데이트할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!