जावा एनआईओ बनाम आईओ
जैसा कि हम जानते हैं कि java NIO को पारंपरिक java IO API की उन्नति के लिए पेश किया गया है। मुख्य संवर्द्धन जो NIO को IO से अधिक कुशल बनाते हैं, NIO में उपयोग किए जाने वाले चैनल डेटा प्रवाह मॉडल और पारंपरिक IO कार्यों के लिए ऑपरेटिंग सिस्टम का उपयोग करते हैं।
जावा एनआईओ और जावा आईओ के बीच अंतर को निम्नलिखित के रूप में समझाया जा सकता है -
जैसा कि I / O परिचालनों के लिए NIO बफ़र और चैनल उन्मुख डेटा प्रवाह में पिछली पोस्ट में उल्लेख किया गया है, जो IO की तुलना में तेज़ निष्पादन और बेहतर प्रदर्शन प्रदान करता है। इसके अलावा NIO पारंपरिक I / O कार्यों के लिए ऑपरेटिंग सिस्टम का उपयोग करता है जो इसे फिर से अधिक कुशल बनाता है।
NIO और IO के बीच अंतर का अन्य पहलू यह है कि यह IO स्ट्रीम लाइन डेटा फ्लो का उपयोग करता है, जो एक बार में एक से अधिक बाइट करता है और डेटा ऑब्जेक्ट्स को बाइट्स और वाइस-ए-वर्सा में परिवर्तित करने पर निर्भर करता है जबकि NIO डेटा ब्लॉक के साथ डील करता है जो बाइट्स का हिस्सा होते हैं।
जावा IO स्ट्रीम ऑब्जेक्ट्स यूनिडायरेक्शनल हैं जबकि NIO चैनल द्विदिश हैं जिसका अर्थ है कि डेटा को पढ़ने और लिखने दोनों के लिए एक चैनल का उपयोग किया जा सकता है।
IO में स्ट्रीमलाइन डेटा प्रवाह डेटा में आगे और पीछे जाने की अनुमति नहीं देता है। यदि मामले में आगे और पीछे डेटा को स्थानांतरित करने की आवश्यकता है, तो स्ट्रीम से पढ़ी गई डेटा को पहले बफर में कैश करना होगा। NIO के मामले में हम बफर उन्मुख का उपयोग करते हैं जो कैशिंग की आवश्यकता के बिना डेटा को आगे और पीछे एक्सेस करने की अनुमति देता है।
NIO API मल्टी थ्रेडिंग को भी सपोर्ट करता है ताकि डेटा को इस तरह से एसिंक्रोनस तरीके से पढ़ा और लिखा जा सके, ताकि IO ऑपरेशंस करते समय करंट थ्रेड ब्लॉक न हो। फिर से इसे पारंपरिक java IO API की तुलना में अधिक कुशल बनाते हैं।
मल्टी थ्रेडिंग की अवधारणा की शुरुआत के साथ शुरू की गई है Selectors जावा NIO में अतुल्यकालिक या गैर अवरुद्ध तरीके से IO घटनाओं के लिए कई चैनलों को सुनने की अनुमति देता है।
NIO में मल्टी थ्रेडिंग, इसे नॉन ब्लॉकिंग बनाता है, जिसका अर्थ है कि थ्रेड को केवल पढ़ने या लिखने के लिए अनुरोध किया जाता है, जब डेटा उपलब्ध हो, अन्यथा थ्रेड को अन्य कार्य में मीन समय के लिए उपयोग किया जा सकता है। लेकिन पारंपरिक जावा IO के मामले में यह संभव नहीं है क्योंकि कोई मल्टी थ्रेडिंग नहीं है इसमें समर्थित है जो इसे ब्लॉकिंग के रूप में बनाता है।
NIO केवल एक ही धागे का उपयोग करके कई चैनलों को प्रबंधित करने की अनुमति देता है, लेकिन लागत यह है कि डेटा को पार्स करने से कुछ अधिक जटिल हो सकता है जब जावा IO के मामले में एक अवरुद्ध स्ट्रीम से डेटा पढ़ने पर। बहुत अधिक बैंडविड्थ के साथ कम कनेक्शन की आवश्यकता होती है एक समय में बहुत अधिक डेटा भेजने के साथ, इस मामले में जावा आईओ एपीआई सबसे उपयुक्त हो सकता है।