>Java >java지도 시간 >Java 8 Streams를 사용하여 중복 요소 발생 횟수를 효율적으로 계산하려면 어떻게 해야 합니까?

Java 8 Streams를 사용하여 중복 요소 발생 횟수를 효율적으로 계산하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-15 04:29:021082검색

How can I use Java 8 Streams to efficiently count occurrences of duplicate elements?

groupBy를 사용하여 Java 8 스트림에서 발생 횟수 계산

Java 8 스트림에서 groupBy 메서드를 사용하면 특정 속성을 기반으로 요소를 그룹화할 수 있습니다. 또는 가치. 계산과 같은 다른 수집기와 결합하면 스트림에서 중복 요소의 발생을 효율적으로 계산할 수 있습니다.

예를 생각해 보겠습니다.

List<String> list = Arrays.asList("Hello", "Hello", "World");
Map<String, Long> wordToFrequency = list.stream()
    .collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));

이 예에서는 Collector를 인수로 사용하는 오버로드가 있는 Collect 메서드입니다. 컬렉터 내에서는 groupingBy를 사용하여 문자열 값(ID 함수)을 기준으로 항목을 그룹화합니다. 그런 다음 이를 Collectors.counting()과 결합하여 각 고유 문자열의 발생 횟수를 계산합니다.

결과적으로 각 키가 고유 문자열이고 해당 값이 다음에서 발생하는 횟수인 맵을 얻습니다. 목록. 이 경우 맵에는 다음이 포함됩니다.

{Hello=2, World=1}

이 접근 방식은 매우 효율적이고 사용하기 쉬우므로 특정 속성을 기반으로 스트림에서 요소의 발생 횟수를 계산해야 하는 다양한 시나리오에 적합합니다. . 적절한 경우 성능 향상을 위해 groupingByConcurrent를 활용할 수도 있습니다.

위 내용은 Java 8 Streams를 사용하여 중복 요소 발생 횟수를 효율적으로 계산하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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