जावा एनआईओ - पाइप

जावा में NIO पाइप एक घटक है जो दो थ्रेड्स के बीच डेटा लिखने और पढ़ने के लिए उपयोग किया जाता है। मुख्य रूप से दो चैनल होते हैं जो डेटा प्रसार के लिए जिम्मेदार होते हैं।

दो घटक चैनलों में से एक को सिंक चैनल कहा जाता है जो मुख्य रूप से डेटा लिखने के लिए है और अन्य स्रोत चैनल है जिसका मुख्य उद्देश्य सिंक चैनल के डेटा को पढ़ना है।

डेटा सिंक्रनाइज़ेशन को डेटा लिखने और पढ़ने के दौरान क्रम में रखा जाता है क्योंकि यह सुनिश्चित किया जाना चाहिए कि डेटा को उसी क्रम में पढ़ा जाना चाहिए जिसमें यह पाइप को लिखा गया है।

यह ध्यान में रखा जाना चाहिए कि यह पाइप में डेटा का एक यूनिडायरेक्शनल प्रवाह है। डेटा केवल सिंक चैनल में लिखा गया है और केवल स्रोत चैनल से पढ़ा जा सकता है।

जावा में NIO पाइप को मुख्य रूप से तीन विधियों के साथ एक सार वर्ग के रूप में परिभाषित किया गया है जिसमें से दो सार हैं।

पाइप वर्ग के तरीके

  • open() - इस विधि का उपयोग पाइप का एक उदाहरण प्राप्त करने के लिए किया जाता है या हम कह सकते हैं कि इस विधि को कॉल करके पाइप बनाया जाता है।

  • sink() - यह विधि पाइप के सिंक चैनल को लौटाती है जिसका उपयोग इसकी लेखन विधि को कॉल करके डेटा लिखने के लिए किया जाता है।

  • source() - यह विधि पाइप के स्रोत चैनल को लौटाती है जिसका उपयोग इसकी रीड विधि को कॉल करके डेटा को पढ़ने के लिए किया जाता है।

उदाहरण

निम्न उदाहरण जावा एनआईओ पाइप के कार्यान्वयन को दर्शाता है।

import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.channels.Pipe;

public class PipeDemo {
   public static void main(String[] args) throws IOException {
      //An instance of Pipe is created
      Pipe pipe = Pipe.open();
      // gets the pipe's sink channel
      Pipe.SinkChannel skChannel = pipe.sink();
      String testData = "Test Data to Check java NIO Channels Pipe.";
      ByteBuffer buffer = ByteBuffer.allocate(512);
      buffer.clear();
      buffer.put(testData.getBytes());
      buffer.flip();
      //write data into sink channel.
      while(buffer.hasRemaining()) {
         skChannel.write(buffer);
      }
      //gets  pipe's source channel
      Pipe.SourceChannel sourceChannel = pipe.source();
      buffer = ByteBuffer.allocate(512);
      //write data into console     
      while(sourceChannel.read(buffer) > 0){
         //limit is set to current position and position is set to zero
         buffer.flip();
         while(buffer.hasRemaining()){
            char ch = (char) buffer.get();
            System.out.print(ch);
         }
         //position is set to zero and limit is set to capacity to clear the buffer.
         buffer.clear();
      }
   }
}

उत्पादन

Test Data to Check java NIO Channels Pipe.

मान लें कि हमारे पास एक पाठ फ़ाइल है c:/test.txt, जिसमें निम्नलिखित सामग्री है। यह फ़ाइल हमारे उदाहरण कार्यक्रम के लिए एक इनपुट के रूप में उपयोग की जाएगी।