Rumah >pembangunan bahagian belakang >Golang >Adakah Terdapat Java Setara dengan `pilih` Go untuk Membaca Secara Cekap daripada Berbilang Baris Sekatan?
Setara dengan Go Channel di Java
Soalan:
Saya perlu membaca data dengan cekap daripada berbilang baris gilir menyekat tanpa membuat utas pembaca yang berasingan. Adakah terdapat mekanisme yang setara dengan pemilihan/epoll Go di Java?
Jawapan:
Pertimbangkan untuk menggunakan perpustakaan JCSP, yang menyediakan kelas Alternatif. Alternatif adalah setanding dengan pernyataan pilihan Go. Ia membolehkan anda mencipta urutan pengguna tunggal yang boleh memultiplekskan data daripada berbilang saluran sumber tanpa memerlukan tinjauan berterusan.
Kelebihan Alternatif JCSP:
Contoh Penggunaan:
Kod Java berikut menunjukkan pemultipleks adil menggunakan JCSP:
import org.jcsp.lang.*; public class FairPlex implements CSProcess { private final AltingChannelInput[] in; private final ChannelOutput out; public FairPlex (final AltingChannelInput[] in, final ChannelOutput out) { this.in = in; this.out = out; } public void run () { final Alternative alt = new Alternative (in); while (true) { final int index = alt.fairSelect (); out.write (in[index].read ()); } } }
Nota Tambahan:
Versi semasa JCSP dalam repositori Maven ialah 1.1-rc5, bertentangan dengan apa yang dinyatakan di tapak web JCSP.
Atas ialah kandungan terperinci Adakah Terdapat Java Setara dengan `pilih` Go untuk Membaca Secara Cekap daripada Berbilang Baris Sekatan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!