जावा एनआईओ - सॉकेट चैनल

Java NIO सॉकेट चैनल एक चुनिंदा प्रकार का चैनल है जिसका अर्थ है कि इसे चयनकर्ता का उपयोग करके गुणा किया जा सकता है, जो धारा उन्मुख डेटा प्रवाह को सॉकेट से कनेक्ट करने के लिए उपयोग किया जाता है। सॉकेट चैनल को अपने स्थैतिक को शामिल करके बनाया जा सकता है open() विधि, कोई भी पहले से मौजूद सॉकेट प्रदान करना पहले से मौजूद नहीं है। सॉकेट चैनल खुली विधि को लागू करके बनाया गया है लेकिन अभी तक जुड़ा नहीं है। सॉकेट चैनल को जोड़ने के लिए connect() विधि को कहा जाता है। यहाँ उल्लेख किया जाना चाहिए। यदि चैनल जुड़ा नहीं है और किसी भी I / O ऑपरेशन का प्रयास करने की कोशिश की जाती है, तो NotYetConnectedException को इस चैनल द्वारा फेंक दिया जाता है। कोई भी यह सुनिश्चित करना चाहिए कि चैनल किसी IO से पहले जुड़ा हुआ है ऑपरेशन। एक चैनल जुड़ा हुआ है, यह बंद होने तक जुड़ा रहता है। सॉकेट चैनल की स्थिति को इसके द्वारा निर्धारित किया जा सकता है isConnected तरीका।

सॉकेट चैनल का कनेक्शन इसे लागू करके समाप्त किया जा सकता है finishConnect() विधि। कोई कनेक्शन ऑपरेशन प्रगति पर है या नहीं, इसे आईकनेक्ट बनाने की विधि द्वारा निर्धारित किया जा सकता है। विधि डिफ़ॉल्ट सॉकेट चैनल नॉन-ब्लॉकिंग कनेक्शन का समर्थन करता है। इसके अलावा यह एसिंक्रोनस शटडाउन का समर्थन करता है, जो चैनल वर्ग में निर्दिष्ट एसिंक्रोनस क्लोज ऑपरेशन के समान है।

सॉकेट चैनल कई समवर्ती धागे द्वारा उपयोग के लिए सुरक्षित हैं। वे समवर्ती पढ़ने और लिखने का समर्थन करते हैं, हालांकि अधिकांश एक धागे में पढ़ा जा सकता है और किसी एक समय पर किसी एक धागे में लिखा जा सकता है। कनेक्ट और फिनिशकनेक्ट तरीके परस्पर एक-दूसरे के खिलाफ सिंक्रनाइज़ किए जाते हैं, और एक पढ़ने या लिखने के संचालन को शुरू करने का प्रयास किया जाता है, जबकि इनमें से किसी एक तरीके का आह्वान प्रगति पर है जब तक कि मंगलाचरण पूरा नहीं हो जाता।

सॉकेट चैनल के महत्वपूर्ण तरीके

  • bind(SocketAddress local) - इस विधि का उपयोग सॉकेट चैनल को स्थानीय पते पर बाँधने के लिए किया जाता है जो इस विधि के पैरामीटर के रूप में प्रदान किया जाता है।

  • connect(SocketAddress remote) - इस विधि का उपयोग सॉकेट को दूरस्थ पते से जोड़ने के लिए किया जाता है।

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

  • getRemoteAddress() - यह विधि रिमोट लोकेशन के पते को लौटाती है जिससे चैनल का सॉकेट जुड़ा होता है।

  • isConnected() - जैसा कि पहले ही उल्लेख किया गया है कि यह विधि सॉकेट चैनल के कनेक्शन की स्थिति लौटाती है अर्थात यह जुड़ा हुआ है या नहीं।

  • open() and open((SocketAddress remote) - ओपन मेथड का उपयोग बिना किसी निर्दिष्ट पते के लिए सॉकेट चैनल खोलने के लिए किया जाता है जबकि निर्दिष्ट रिमोट एड्रेस के लिए ओपन मेथड ओपन मेथड ओपन चैनल भी होता है और इससे कनेक्ट भी होता है। यह सुविधा विधि इस तरह काम करती है जैसे कि ओपन () विधि को लागू करने के बाद, कनेक्ट करने का तरीका सॉकेट चैनल, इसे दूरस्थ रूप से पारित करना, और फिर उस चैनल को वापस करना।

  • read(ByteBuffer dst) - इस विधि का उपयोग सॉकेट चैनल के माध्यम से दिए गए बफर के डेटा को पढ़ने के लिए किया जाता है।

  • isConnectionPending() - यह विधि बताती है कि इस चैनल पर कनेक्शन ऑपरेशन जारी है या नहीं।

उदाहरण

निम्न उदाहरण दिखाता है कि जावा एनआईओ सॉकेटचैनल से डेटा कैसे भेजा जाए।

सी: /Test/temp.txt

Hello World!

ग्राहक: सॉकेटचैनलाइनक्लाइंट। जावा

import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SocketChannel;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.StandardOpenOption;
import java.util.EnumSet;

public class SocketChannelClient {
   public static void main(String[] args) throws IOException {
      ServerSocketChannel serverSocket = null;
      SocketChannel client = null;
      serverSocket = ServerSocketChannel.open();
      serverSocket.socket().bind(new InetSocketAddress(9000));
      client = serverSocket.accept();
      System.out.println("Connection Set:  " + client.getRemoteAddress());
      Path path = Paths.get("C:/Test/temp1.txt");
      FileChannel fileChannel = FileChannel.open(path, 
         EnumSet.of(StandardOpenOption.CREATE, 
            StandardOpenOption.TRUNCATE_EXISTING,
            StandardOpenOption.WRITE)
         );      
      ByteBuffer buffer = ByteBuffer.allocate(1024);
      while(client.read(buffer) > 0) {
         buffer.flip();
         fileChannel.write(buffer);
         buffer.clear();
      }
      fileChannel.close();
      System.out.println("File Received");
      client.close();
   }
}

उत्पादन

क्लाइंट को चलाने से सर्वर शुरू होने तक कुछ भी प्रिंट नहीं होगा।

सर्वर: सॉकेटचैनलाइनरवर.जावा

import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.nio.channels.SocketChannel;
import java.nio.file.Path;
import java.nio.file.Paths;

public class SocketChannelServer {
   public static void main(String[] args) throws IOException {
      SocketChannel server = SocketChannel.open();
      SocketAddress socketAddr = new InetSocketAddress("localhost", 9000);
      server.connect(socketAddr);

      Path path = Paths.get("C:/Test/temp.txt");
      FileChannel fileChannel = FileChannel.open(path);
      ByteBuffer buffer = ByteBuffer.allocate(1024);
      while(fileChannel.read(buffer) > 0) {
         buffer.flip();
         server.write(buffer);
         buffer.clear();
      }
      fileChannel.close();
      System.out.println("File Sent");
      server.close();
   }
}

उत्पादन

सर्वर चलाना निम्नलिखित प्रिंट करेगा।

Connection Set:  /127.0.0.1:49558
File Received