>Java >java지도 시간 >Java에 SortedList가 없는 이유는 무엇입니까?

Java에 SortedList가 없는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-11 20:35:11594검색

Why Doesn't Java Have a SortedList?

Java에 SortedList가 없는 이유

Java 컬렉션 프레임워크의 SortedSet 및 SortedMap과 달리 Java는 전용 SortedList를 제공하지 않습니다. 이러한 생략에도 불구하고 Java는 java.util.Collections.sort() 메소드를 통해 정렬 기능을 제공합니다.

생략 이유

SortedList가 없기 때문에 발생합니다. 목록 반복자의 기본 특성에서 비롯됩니다. 목록 반복자는 요소의 삽입 순서를 유지하는 데 우선순위를 둡니다. 반면에 정렬은 요소 순서를 변경하여 데이터 구조를 조작하는 것으로 볼 수 있습니다.

SortedList의 대안

  1. SortedSet 및 Multiset (가방):

    • SortedSet는 요소 삽입 중에 정렬을 자동화하여 수동 정렬이 필요하지 않습니다.
    • TreeMultiset(Multiset 구현)은 정렬된 내용을 유지하면서 중복 요소를 허용합니다. order.
  2. Collections.sort():

    • 내부 데이터 구조를 수정하여 목록 인스턴스를 정렬합니다.
    • 사용자 정의 정렬을 위한 비교기를 허용하여 로케일 구분 문자열 정렬을 허용합니다. 인스턴스.
  3. PriorityQueue:

    • SortedList를 직접 대체하지는 않지만 PriorityQueue는 적합한 정렬된 대기열 동작을 제공합니다. 특정 사용 사례의 경우.
    • PriorityQueue를 통한 반복은 다음 요소를 반환합니다. 정렬된 순서.
  4. 사용자 정의 구현:

    • 사용자는 AbstractList 클래스를 확장하고 메서드를 추가하고 정렬합니다.
    • 이 옵션은 목록 인터페이스 계약을 위반하므로 권장되지 않습니다. 기존 솔루션에 비해 큰 이점이 없습니다.

위 내용은 Java에 SortedList가 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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