जावा एनआईओ - बफर

जावा एनआईओ में बफ़र्स को एक साधारण वस्तु के रूप में माना जा सकता है जो डेटा चंक्स के एक निश्चित आकार के कंटेनर के रूप में कार्य करता है जिसका उपयोग चैनल से डेटा लिखने या चैनल से डेटा पढ़ने के लिए किया जा सकता है ताकि बफ़र्स चैनलों के लिए समापन बिंदु के रूप में कार्य करें।

यह उन तरीकों का सेट प्रदान करता है जो चैनलों से डेटा को पढ़ने और लिखने के लिए मेमोरी ब्लॉक से निपटने के लिए अधिक सुविधाजनक बनाते हैं।

बफ़र्स क्लासिक IO की तुलना में NIO पैकेज को अधिक कुशल और तेज़ बनाता है क्योंकि IO डेटा धाराओं के रूप में व्यवहार किया जाता है जो डेटा के अतुल्यकालिक और समवर्ती प्रवाह का समर्थन नहीं करता है। इसके अलावा IO chunk या बाइट्स के समूह में डेटा निष्पादन की अनुमति नहीं देता है ।

जावा NIO बफर को परिभाषित करने वाले प्राथमिक मापदंडों को निम्न के रूप में परिभाषित किया जा सकता है -

  • Capacity - अधिकतम डेटा / बाइट जो बफ़र में संग्रहीत किया जा सकता है। बफर की क्षमता को परिवर्तित नहीं किया जा सकता है। बफ़र पूर्ण होने पर इसे लिखने से पहले इसे साफ़ किया जाना चाहिए।

  • Limit - सीमा का अर्थ बफ़र के मोड के अनुसार होता है अर्थात बफ़र लिमिट के लिखित मोड में क्षमता के बराबर है जिसका अर्थ है कि अधिकतम डेटा जो बफर में लिखा जा सकता है। बफर मोड के रीड मोड में लिली का अर्थ है कि कितना डेटा हो सकता है बफ़र से पढ़ें।

  • Position - बफर में कर्सर के वर्तमान स्थान को इंगित करता है। आमतौर पर बफर के निर्माण के समय 0 के रूप में बस गया या दूसरे शब्दों में यह पढ़ने या लिखे जाने वाले अगले तत्व का सूचकांक है जो स्वचालित रूप से अपडेट होकर प्राप्त होता है () और डाल () ) तरीके।

  • Mark - बफर में स्थिति का एक बुकमार्क चिह्नित करें। जब चिह्न () विधि कहा जाता है वर्तमान स्थिति दर्ज की जाती है और जब रीसेट () कहा जाता है तो चिह्नित स्थिति बहाल हो जाती है।

बफर प्रकार

जावा NIO बफ़र को निम्न प्रकार के डेटा के आधार पर निम्न प्रकारों में वर्गीकृत किया जा सकता है -

  • ByteBuffer
  • MappedByteBuffer
  • CharBuffer
  • DoubleBuffer
  • FloatBuffer
  • IntBuffer
  • LongBuffer
  • ShortBuffer

बफर के महत्वपूर्ण तरीके

जैसा कि पहले ही उल्लेख किया जा चुका है कि बफर मेमोरी ऑब्जेक्ट के रूप में कार्य करता है जो मेमोरी ब्लॉक से निपटने के लिए अधिक सुविधाजनक बनाने वाले तरीकों का सेट प्रदान करता है। फ़्लोरिंग बफर के महत्वपूर्ण तरीके हैं -

  • allocate(int capacity) - यह विधि पैरामीटर के रूप में क्षमता के साथ एक नया बफर आवंटित करने के लिए उपयोग की जाती है। पारित विधि एक नकारात्मक पूर्णांक है, इस मामले में IllegalArgumentException को फेंकता है।

  • read() and put() - चैनल की रीड मेथड का उपयोग चैनल से बफर में डेटा लिखने के लिए किया जाता है जबकि पुट बफर की एक विधि है जिसका उपयोग बफर में डेटा लिखने के लिए किया जाता है।

  • flip() - फ्लिप विधि बफ़र के मोड को लेखन मोड से रीडिंग मोड पर स्विच करती है। यह स्थिति को वापस 0 पर सेट करता है, और उस सीमा को सेट करता है जहां लेखन के समय स्थिति थी।

  • write() and get() - चैनल का लेखन विधि का उपयोग बफर से चैनल पर डेटा लिखने के लिए किया जाता है, जबकि बफर बफर की एक विधि है जिसका उपयोग बफर से डेटा पढ़ने के लिए किया जाता है।

  • rewind() - रिवाइंड विधि का उपयोग तब किया जाता है जब रीड की आवश्यकता होती है क्योंकि यह स्थिति को शून्य पर सेट करता है और सीमा के मूल्य में परिवर्तन नहीं करता है।

  • clear() and compact() - क्लियर और कॉम्पैक्ट दोनों तरीकों का उपयोग रीड से राइट मोड में बफर बनाने के लिए किया जाता है।clear() विधि शून्य की स्थिति बनाती है और सीमा क्षमता के बराबर होती है, इस विधि में बफर में डेटा को केवल क्लीयर नहीं किया जाता है क्योंकि इसे आरंभिक रूप दिया जाता है।

    दुसरी तरफ compact() विधि का उपयोग तब होता है जब कुछ अन-रीड डेटा रहता है और फिर भी हम बफर के लेखन मोड का उपयोग करते हैं, इस मामले में कॉम्पैक्ट विधि बफर की शुरुआत में सभी अपठित डेटा को कॉपी करती है और अंतिम अपठित तत्व के बाद स्थिति को सही सेट करती है। सीमा संपत्ति अभी भी है क्षमता के लिए सेट।

  • mark() and reset() - जैसा कि नाम से पता चलता है कि मार्क विधि का उपयोग बफर में किसी विशेष स्थिति को चिह्नित करने के लिए किया जाता है जबकि रीसेट स्थिति को चिह्नित स्थिति में वापस कर देता है।

उदाहरण

निम्नलिखित उदाहरण उपरोक्त परिभाषित तरीकों के कार्यान्वयन को दर्शाता है।

import java.nio.ByteBuffer;
import java.nio.CharBuffer;

public class BufferDemo {
   public static void main (String [] args) {
      //allocate a character type buffer.
      CharBuffer buffer = CharBuffer.allocate(10);
      String text = "bufferDemo";
      System.out.println("Input text: " + text);
      for (int i = 0; i < text.length(); i++) {
         char c = text.charAt(i);
         //put character in buffer.
		 buffer.put(c);
      }
      int buffPos = buffer.position();
      System.out.println("Position after data is written into buffer: " + buffPos);
      buffer.flip();
      System.out.println("Reading buffer contents:");
      while (buffer.hasRemaining()) {
         System.out.println(buffer.get());                   
      }
      //set the position of buffer to 5.
      buffer.position(5);
      //sets this buffer's mark at its position
      buffer.mark();
      //try to change the position
      buffer.position(6);
      //calling reset method to restore to the position we marked.
      //reset() raise InvalidMarkException if either the new position is less
      //than the position marked or merk has not been setted.
      buffer.reset();
      System.out.println("Restored buffer position : " + buffer.position());
   }
}

उत्पादन

Input text: bufferDemo
Position after data is written into buffer: 10
Reading buffer contents:
b
u
f
f
e
r
D
e
m
o
Restored buffer position : 5