groupBy를 사용하여 발생 횟수 계산
Java 스트림의 groupBy 메서드를 사용하면 지정된 키를 기반으로 요소를 그룹으로 수집할 수 있습니다. 이 경우 문자열을 값별로 그룹화하고 각 그룹 내에서 발생 횟수를 계산하려고 합니다.
이를 달성하기 위해 두 번째 수집기를 사용하는 groupBy의 오버로드를 사용할 수 있습니다. Collectors.counting()을 이 Collector로 제공하여 각 그룹 내의 요소 수를 계산합니다.
스트림을 사용하여 이를 구현하는 방법은 다음과 같습니다.
import java.util.*; import java.util.stream.*; class Test { public static void main(String[] args) { List<String> list = new ArrayList<>(); list.add("Hello"); list.add("Hello"); list.add("World"); Map<String, Long> counted = list.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.counting())); System.out.println(counted); } }
이렇게 하면 다음이 생성됩니다. 출력:
{Hello=2, World=1}
맵에는 두 개의 항목이 포함되어 있으며 "Hello"는 2로 매핑되고 "World"는 1로 매핑됩니다. 이는 입력 목록의 각 단어에 대한 발생 횟수를 나타냅니다.
특히 동시 실행이 안전한 시나리오에서는 효율성 향상을 위해 groupingByConcurrent를 사용할 수도 있습니다.
위 내용은 Java 스트림을 사용하여 목록에서 문자열 발생을 어떻게 계산할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!