Stream의 max 함수는 스트림 내 최대값을 편리하게 식별합니다. 그러나 "선착순" 원칙에 따라 작동하므로 동률이 있는 경우 잠재적으로 다른 최대값을 제외할 수 있습니다. 이 제한 사항을 해결하고 모든 최대값을 검색하려면 대체 접근 방식이 필요합니다.
입력 수집의 경우 2단계 접근 방식을 사용할 수 있습니다.
이 솔루션은 여러 최대값을 수용하지만 전체 입력을 두 번 반복하는 비용이 발생합니다.
입력이 스트림의 경우 단일 패스 수집기를 활용할 수 있습니다.
static <T> Collector<T, ?, List<T>> maxList(Comparator<? super T> comp) { return Collector.of( ArrayList::new, (list, t) -> { if (list.isEmpty() || comp.compare(t, list.get(0)) == 0) { list.add(t); } else if (comp.compare(t, list.get(0)) > 0) { list.clear(); list.add(t); } }, (list1, list2) -> { ... // Compare and merge lists based on maximum values } ); }
이 수집기는 동등성, 필요에 따라 요소를 추가하거나 제거합니다. 목록을 병합할 때 각 요소의 최대값을 고려하여 동일할 때 결합합니다.
이 컬렉터를 스트림과 결합하면 단일 패스에서 모든 최대값을 얻을 수 있습니다.
Java 스트림의 max에는 한계가 있지만 대체 솔루션을 활용하여 이를 극복할 수 있습니다. 2패스 솔루션은 수집에 효율적인 반면, 단일 패스 수집기는 스트림에 유용하여 모든 최대값을 검색할 수 있습니다.
위 내용은 Java 스트림에서 모든 최대값을 검색하여 동점을 효과적으로 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!