जावा एनआईओ - चैनल
विवरण
जैसा कि नाम से पता चलता है कि चैनल एक छोर से दूसरे छोर तक डेटा प्रवाह के माध्यम के रूप में उपयोग किया जाता है। java NIO चैनल में बफर के बीच एक ही कार्य करते हैं और दूसरे शब्दों में चैनल के दूसरे छोर पर एक इकाई डेटा को बफर में पढ़ने और बफर से डेटा लिखने के लिए उपयोग किया जाता है।
पारंपरिक जावा IO चैनलों में उपयोग की जाने वाली धाराओं के विपरीत, दो तरह से हैं, साथ ही लिख सकते हैं। Java NIO चैनल अवरुद्ध और गैर-अवरुद्ध मोड दोनों में डेटा के अतुल्यकालिक प्रवाह का समर्थन करता है।
चैनल का कार्यान्वयन
जावा एनआईओ चैनल मुख्य रूप से निम्नलिखित वर्गों में लागू किया जाता है -
FileChannel- फाइल से डेटा पढ़ने के लिए हम फाइल चैनल का उपयोग करते हैं। फ़ाइल चैनल का ऑब्जेक्ट केवल फ़ाइल ऑब्जेक्ट पर getChannel () पद्धति को कॉल करके बनाया जा सकता है क्योंकि हम सीधे फ़ाइल ऑब्जेक्ट नहीं बना सकते हैं।
DatagramChannel - डेटाग्राम चैनल नेटवर्क पर डेटा को यूडीपी (यूजर डेटाग्राम प्रोटोकॉल) के माध्यम से पढ़ और लिख सकता है। डेटाग्रैमचैनल के किसी भी विषय को कारखाने के तरीकों का उपयोग करके बनाया जा सकता है।
SocketChannel- सॉकेटचैनल चैनल टीसीपी (ट्रांसमिशन कंट्रोल प्रोटोकॉल) के माध्यम से नेटवर्क पर डेटा पढ़ और लिख सकता है। यह नई वस्तु बनाने के लिए कारखाने के तरीकों का भी उपयोग करता है।
ServerSocketChannel- ServerSocketChannel एक वेब सर्वर के समान टीसीपी कनेक्शन पर डेटा पढ़ता और लिखता है। हर आने वाले कनेक्शन के लिए एक सॉकेटचैनल बनाया जाता है।
उदाहरण
निम्नलिखित उदाहरण एक पाठ फ़ाइल से पढ़ता है C:/Test/temp.txt और सामग्री को कंसोल पर प्रिंट करता है।
temp.txt
Hello World!
ChannelDemo.java
import java.io.IOException;
import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
public class ChannelDemo {
public static void main(String args[]) throws IOException {
RandomAccessFile file = new RandomAccessFile("C:/Test/temp.txt", "r");
FileChannel fileChannel = file.getChannel();
ByteBuffer byteBuffer = ByteBuffer.allocate(512);
while (fileChannel.read(byteBuffer) > 0) {
// flip the buffer to prepare for get operation
byteBuffer.flip();
while (byteBuffer.hasRemaining()) {
System.out.print((char) byteBuffer.get());
}
}
file.close();
}
}
उत्पादन
Hello World!