जावा एनआईओ - चयनकर्ता
जैसा कि हम जानते हैं कि जावा एनआईओ एक या अधिक एनआईओ चैनल की जांच करने के लिए चैनलों और बफर से कई लेनदेन का समर्थन करता है। और यह निर्धारित करता है कि कौन से चैनल डेटा लेनदेन के लिए तैयार हैं या जावा एनआईओ लिखने या पढ़ने के लिए चयनकर्ता प्रदान करते हैं।
चयनकर्ता के साथ हम यह जानने के लिए एक धागा बना सकते हैं कि कौन सा चैनल डेटा लिखने और पढ़ने के लिए तैयार है और उस विशेष चैनल का सौदा कर सकता है।
हम इसकी स्थैतिक विधि को कॉल करके चयनकर्ता उदाहरण प्राप्त कर सकते हैं open()। खुले चयनकर्ता के बाद हमें इसके साथ एक नॉन ब्लॉकिंग मोड चैनल रजिस्टर करना होगा जो SelectionKey का एक उदाहरण देता है।
SelectionKey मूल रूप से संचालन का एक संग्रह है जिसे चैनल के साथ किया जा सकता है या हम कह सकते हैं कि हम चयन कुंजी की सहायता से चैनल की स्थिति जान सकते हैं।
चयन कुंजी द्वारा प्रस्तुत चैनल के प्रमुख संचालन या स्थिति हैं -
SelectionKey.OP_CONNECT - चैनल जो सर्वर से जुड़ने के लिए तैयार है।
SelectionKey.OP_ACCEPT - चैनल जो आने वाले कनेक्शनों को स्वीकार करने के लिए तैयार है।
SelectionKey.OP_READ - चैनल जो डेटा पढ़ने के लिए तैयार है।
SelectionKey.OP_WRITE - चैनल जो डेटा लिखने के लिए तैयार है।
पंजीकरण के बाद प्राप्त चयन कुंजी में कुछ महत्वपूर्ण विधियां हैं जैसा कि नीचे वर्णित है -
attach() - इस विधि का उपयोग किसी वस्तु को कुंजी के साथ संलग्न करने के लिए किया जाता है। किसी चैनल को एक वस्तु संलग्न करने का मुख्य उद्देश्य उसी चैनल को पहचानना है।
attachment() - इस विधि का उपयोग चैनल से जुड़ी वस्तु को बनाए रखने के लिए किया जाता है।
channel() - इस विधि का उपयोग चैनल प्राप्त करने के लिए किया जाता है जिसके लिए विशेष कुंजी बनाई जाती है।
selector() - इस विधि का उपयोग चयनकर्ता को प्राप्त करने के लिए किया जाता है जिसके लिए विशेष कुंजी बनाई जाती है।
isValid() - यह विधि मौसम की कुंजी को वैध मानती है या नहीं।
isReadable() - यह विधि बताती है कि मौसम की कुंजी का चैनल पढ़ने के लिए तैयार है या नहीं।
isWritable() - यह विधि बताती है कि मौसम की कुंजी का चैनल लिखने के लिए तैयार है या नहीं।
isAcceptable() - यह विधि बताती है कि आने वाले कनेक्शन को स्वीकार करने या नहीं करने के लिए मौसम की कुंजी का चैनल तैयार है।
isConnectable() - यह विधि परीक्षण करती है कि क्या इस कुंजी का चैनल या तो समाप्त हो गया है, या समाप्त होने में विफल है, इसका सॉकेट-कनेक्शन ऑपरेशन।
isAcceptable() - यह विधि परीक्षण करती है कि क्या यह कुंजी चैनल एक नए सॉकेट कनेक्शन को स्वीकार करने के लिए तैयार है या नहीं।
interestOps() - यह विधि इस कुंजी के ब्याज सेट को पुनः प्राप्त करती है।
readyOps() - यह विधि तैयार सेट को पुनः प्राप्त करती है जो कि ऑपरेशन का सेट है जिसके लिए चैनल तैयार है।
हम चयनकर्ता से इसकी स्थैतिक विधि कहकर एक चैनल का चयन कर सकते हैं select()चयनकर्ता की चयन विधि अधिक भार के रूप में है -
select() - यह विधि वर्तमान थ्रेड को तब तक अवरुद्ध करती है जब तक कि कम से कम एक चैनल उन घटनाओं के लिए तैयार न हो जाए जिनके लिए यह पंजीकृत है।
select(long timeout) - यह विधि चुनिंदा () के समान है, सिवाय इसके कि यह अधिकतम टाइमआउट मिलीसेकंड (पैरामीटर) के लिए थ्रेड को ब्लॉक करता है।
selectNow() - यह विधि बिल्कुल भी ब्लॉक नहीं होती है। जो भी चैनल तैयार हैं, उनके साथ यह तुरंत लौटता है।
इसके अलावा एक ब्लॉक किए गए धागे को छोड़ने के लिए जो चयन विधि को कॉल करता है,wakeup() विधि को चयनकर्ता उदाहरण से बुलाया जा सकता है जिसके बाद चयन () के अंदर प्रतीक्षा धागा तुरंत वापस आ जाएगा।
अंत में हम चयनकर्ता को कॉल करके बंद कर सकते हैं close() विधि जो चयनकर्ता को बंद करने के साथ इस चयनकर्ता के साथ पंजीकृत सभी SelectionKey उदाहरणों को भी अमान्य करती है।
उदाहरण
import java.io.FileInputStream;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.util.Iterator;
import java.util.Set;
public class SelectorDemo {
public static void main(String[] args) throws IOException {
String demo_text = "This is a demo String";
Selector selector = Selector.open();
ServerSocketChannel serverSocket = ServerSocketChannel.open();
serverSocket.bind(new InetSocketAddress("localhost", 5454));
serverSocket.configureBlocking(false);
serverSocket.register(selector, SelectionKey.OP_ACCEPT);
ByteBuffer buffer = ByteBuffer.allocate(256);
while (true) {
selector.select();
Set<SelectionKey> selectedKeys = selector.selectedKeys();
Iterator<SelectionKey> iter = selectedKeys.iterator();
while (iter.hasNext()) {
SelectionKey key = iter.next();
int interestOps = key.interestOps();
System.out.println(interestOps);
if (key.isAcceptable()) {
SocketChannel client = serverSocket.accept();
client.configureBlocking(false);
client.register(selector, SelectionKey.OP_READ);
}
if (key.isReadable()) {
SocketChannel client = (SocketChannel) key.channel();
client.read(buffer);
if (new String(buffer.array()).trim().equals(demo_text)) {
client.close();
System.out.println("Not accepting client messages anymore");
}
buffer.flip();
client.write(buffer);
buffer.clear();
}
iter.remove();
}
}
}
}