Dalam Java 8, antara muka Spliterator baharu (pembahagi "pemecah belah") telah ditambah, yang boleh digunakan untuk melaksanakan operasi pembahagi pada aliran data. Antara muka ini boleh membahagikan jujukan elemen kepada ketulan kecil, yang boleh diproses secara berasingan dan diproses secara selari untuk prestasi yang lebih baik.
Dalam artikel ini, kita akan belajar cara menggunakan antara muka Spliterator untuk operasi splitter.
Spliterator ialah antara muka baharu dalam Java 8, yang digunakan untuk menyokong pemprosesan penstriman data. Ia adalah singkatan "split-iterator", yang bermaksud bahawa aliran data boleh dibahagikan kepada beberapa kepingan kecil, dan kepingan kecil ini boleh diproses secara bebas. Antara muka ini boleh digunakan untuk mengendalikan pengumpulan data seperti koleksi, tatasusunan, penimbal I/O dan strim Java.
Terdapat beberapa kaedah biasa dalam antara muka Spliterator:
① kaedah tryAdvance():
Kaedah ini digunakan untuk memproses setiap elemen dalam aliran data Jika tiada lagi elemen untuk diproses, ia akan mengembalikan palsu, sebaliknya Kembalikan benar .
② kaedah trySplit():
Kaedah ini membahagikan aliran data kepada dua subkutipan, yang boleh diproses secara selari. Jika aliran data terlalu kecil untuk dipecahkan, null akan dikembalikan.
③ kaedah estimateSize():
Kaedah ini mengembalikan anggaran bilangan elemen dalam aliran data.
④ kaedah ciri():
Kaedah ini mengembalikan ciri elemen dalam aliran data.
Kami boleh melakukan operasi splitter pada aliran data dengan memanggil kaedah antara muka Spliterator. Berikut ialah contoh kod menggunakan Spliterator:
import java.util.ArrayList; import java.util.List; import java.util.Spliterator; public class SplitIteratorExample { public static void main(String[] args) { List<String> names = new ArrayList<>(); names.add("John"); names.add("Mike"); names.add("Tom"); names.add("Jerry"); names.add("Peter"); Spliterator<String> s1 = names.spliterator(); System.out.println("Estimate size: " + s1.estimateSize()); System.out.println("Characteristics: " + s1.characteristics()); s1.forEachRemaining(name -> System.out.println(name)); Spliterator<String> s2 = s1.trySplit(); System.out.println("Spliterator s1"); s1.forEachRemaining(name -> System.out.println(name)); System.out.println("Spliterator s2"); s2.forEachRemaining(name -> System.out.println(name)); } }
Kod sampel ini mencipta senarai rentetan dan menyimpannya dalam objek Senarai bernama "nama". Kami memanggil kaedah spiterator Senarai dan memperoleh contoh Spliterator s1. Kemudian kita boleh menggunakan kaedah dalam Spliterator ini untuk melaksanakan operasi pembahagi pada aliran data.
Pertama, kami memanggil kaedah estimateSize(), yang mengembalikan anggaran bilangan elemen dalam aliran data. Kami memanggil kaedah ciri () untuk mengembalikan ciri unsur dalam aliran data.
Kemudian, kami menggunakan kaedah forEachRemaining() untuk menggelungkan semua elemen dalam keseluruhan strim Parameter kaedah ini ialah ungkapan Lambda untuk memproses setiap elemen.
Seterusnya, kami memanggil kaedah trySplit() untuk memisahkan aliran data kepada dua sub-set s1 dan s2. Kami menggunakan kaedah forEachRemaining() untuk mencetak elemen dalam pemisahan s1 dan s2 masing-masing.
Antara muka Spliterator Java 8 boleh digunakan untuk melaksanakan operasi pembahagi pada aliran data. Ia boleh memisahkan aliran data kepada ketulan kecil dan memproses ketulan ini secara selari untuk meningkatkan kecekapan. Dengan melaksanakan kaedah antara muka Spliterator, kami boleh mengendalikan pengumpulan data seperti koleksi, tatasusunan, penimbal I/O dan aliran Java. Antara muka ini memberikan kami cara yang lebih mudah dan cekap untuk mengendalikan aliran data.
Atas ialah kandungan terperinci Cara menggunakan fungsi Spliterator untuk operasi splitter dalam Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!