Rumah >Java >javaTutorial >Bagaimana saya menggunakan API Java's Nio (Input/Output Baru) untuk I/O yang tidak menyekat?
Artikel ini menerangkan NIO API Java untuk I/O yang tidak menyekat, menggunakan pemilih dan saluran untuk mengendalikan pelbagai sambungan dengan cekap dengan satu benang. Ia memperincikan proses, faedah (skalabilitas, prestasi), dan potensi perangkap (kerumitan,
Java NIO membolehkan operasi I/O yang tidak menyekat terutamanya melalui penggunaan objek Selector
dan SelectableChannel
. Daripada menyekat benang sambil menunggu data, satu benang boleh memantau pelbagai saluran menggunakan Selector
. Ini secara drastik meningkatkan kecekapan, terutamanya apabila mengendalikan banyak sambungan serentak.
Inilah pecahan proses:
ServerSocketChannel
untuk mendengar sambungan masuk, SocketChannel
untuk sambungan yang ditetapkan). Saluran ini mesti dikonfigurasikan untuk operasi tidak menyekat menggunakan channel.configureBlocking(false);
Selector
bertindak sebagai multiplexer, memantau pelbagai saluran untuk acara. Anda mendaftarkan setiap saluran dengan pemilih, menyatakan jenis peristiwa yang anda minati (misalnya, SelectionKey.OP_ACCEPT
, SelectionKey.OP_READ
, SelectionKey.OP_WRITE
). Pendaftaran ini dilakukan menggunakan selector.register(channel, ops, attachment);
di mana attachment
boleh menjadi objek untuk dikaitkan dengan saluran.selector.select()
blok kaedah sehingga sekurang -kurangnya satu saluran berdaftar siap untuk operasi I/O. Sebagai alternatif, selector.selectNow()
kembali dengan segera, walaupun tiada saluran siap.select()
pulangan, anda melangkah melalui kekunci yang dipilih menggunakan selector.selectedKeys()
. Setiap kunci mewakili saluran dengan acara siap. Anda mengambil saluran dari kunci dan melakukan operasi yang sesuai (menerima sambungan baru, data membaca, data menulis).Contoh coretan (ilustrasi):
<code class="java">import java.nio.channels.*; import java.io.*; import java.net.*; import java.util.*; public class NonBlockingServer { public static void main(String[] args) throws IOException { ServerSocketChannel serverChannel = ServerSocketChannel.open(); serverChannel.configureBlocking(false); serverChannel.bind(new InetSocketAddress(8080)); Selector selector = Selector.open(); serverChannel.register(selector, SelectionKey.OP_ACCEPT); while (true) { selector.select(); Set<selectionkey> selectedKeys = selector.selectedKeys(); Iterator<selectionkey> iterator = selectedKeys.iterator(); while (iterator.hasNext()) { SelectionKey key = iterator.next(); iterator.remove(); if (key.isAcceptable()) { // Accept new connection } else if (key.isReadable()) { // Read data from channel } else if (key.isWritable()) { // Write data to channel } } } } }</selectionkey></selectionkey></code>
Ini adalah contoh yang mudah; Pengendalian ralat dan operasi I/O lengkap dihilangkan untuk keringkasan.
Java Nio menawarkan kelebihan yang signifikan ke atas penyekatan tradisional I/O, terutamanya dalam aplikasi tinggi melalui:
Selector
, tidak seperti I/O tradisional di mana setiap sambungan memerlukan benang khusus. Ini secara drastik mengurangkan penggunaan sumber (benang mahal).Pada dasarnya, NIO membolehkan seni bina yang lebih efisien dan berskala untuk mengendalikan banyak permintaan pelanggan serentak berbanding dengan model benang-per-sambungan tradisional.
Sifat tidak menghalang Java Nio menjadikannya sesuai untuk mengendalikan banyak pelanggan secara serentak. Kunci terletak pada penggunaan Selector
yang cekap dan pengendalian operasi I/O yang betul:
Selector
membolehkan satu benang untuk memantau pelbagai saluran untuk acara. Ini adalah teras pengendalian konkurensi yang cekap di NIO.Melaksanakan I/O yang tidak menyekat dengan Java Nio dapat mengemukakan cabaran jika tidak ditangani dengan teliti:
Dengan berhati-hati menangani masalah ini, pemaju berjaya memanfaatkan kuasa dan kecekapan Java Nio untuk membina aplikasi berprestasi tinggi, berskala.
Atas ialah kandungan terperinci Bagaimana saya menggunakan API Java's Nio (Input/Output Baru) untuk I/O yang tidak menyekat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!