Mengira Kejadian dengan GroupBy dalam Java Stream
Java Stream API menyediakan mekanisme berkuasa untuk memanipulasi dan mengagregatkan data dengan cekap. Satu tugas biasa ialah mengira kejadian unsur dalam aliran. Mencapai ini dengan kaedah groupBy() memerlukan memanfaatkan pengumpul tambahan.
Pertimbangkan coretan kod berikut, yang bertujuan untuk mengumpul elemen dalam strim ke dalam peta di mana kunci mewakili elemen unik dan nilai mewakili kejadiannya:
List<String> list = Arrays.asList("Hello", "Hello", "World"); // Desired output: // {Hello=2, World=1}
Untuk mencapai ini, kita boleh menggunakan kaedah groupBy() dengan pengumpul Collectors.counting() untuk melaksanakan mengira:
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); } }
Penjelasan:
Peta dikira yang terhasil akan mempunyai kunci sebagai elemen dan nilai sebagai kiraan masing-masing:
{Hello=2, World=1}
Sebagai alternatif, untuk pertimbangan kecekapan dalam senario tertentu, anda boleh meneroka menggunakan Pengumpul .groupingByConcurrent. Ingat untuk menilai sama ada kes penggunaan khusus anda sejajar dengan keperluan keselamatan pengelompokan serentak.
Atas ialah kandungan terperinci Bagaimanakah saya mengira kejadian elemen dalam Java Stream menggunakan `groupBy()`?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!