जावा एनआईओ - डेटाग्राम चैनल

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

FileChannel का डेटाग्राम चैनल समान रूप से जुड़ा हुआ नहीं है, इसे जोड़ने के लिए हमें स्पष्ट रूप से इसके कनेक्ट () विधि को कॉल करना होगा। किसी भी समय इसे भेजने और प्राप्त करने के तरीकों के लिए डेटाग्राम चैनल को कनेक्ट होने की आवश्यकता नहीं है, जबकि यह जुड़ा होना चाहिए पढ़ने और लिखने के तरीकों का उपयोग करने के लिए, क्योंकि वे तरीके सॉकेट पतों को स्वीकार या वापस नहीं करते हैं।

हम डाटाग्राम चैनल की कनेक्शन स्थिति को कॉल करके जांच सकते हैं isConnected() पद्धति। जुड़ा हुआ है, जब तक यह डिस्कनेक्ट या बंद नहीं हो जाता है, तब तक एक डेटाग्राम चैनल जुड़ा रहता है। डटाग्राम चैनल थ्रेड सुरक्षित होते हैं और एक साथ मल्टी-थ्रेडिंग और कॉन्सिलेटर का समर्थन करते हैं।

डेटाग्राम चैनल के महत्वपूर्ण तरीके

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

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

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

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

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

  • open() and open(ProtocolFamily family) - ओपन मेथड का उपयोग सिंगल एड्रेस के लिए एक डाटाग्राम चैनल खोलने के लिए किया जाता है, जबकि पैराट्रिमेड ओपन मेथड ओपन चैनल मल्टीपल एड्रेस के लिए प्रोटोकॉल परिवार के रूप में दर्शाया जाता है।

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

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

  • send(ByteBuffer src, SocketAddress target) - इस चैनल के माध्यम से डेटाग्राम भेजने के लिए इस विधि का उपयोग किया जाता है।

उदाहरण

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

सर्वर: DatagramChannelServer.java

import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.DatagramChannel;

public class DatagramChannelServer {
   public static void main(String[] args) throws IOException {
      DatagramChannel server = DatagramChannel.open();
      InetSocketAddress iAdd = new InetSocketAddress("localhost", 8989);
      server.bind(iAdd);
      System.out.println("Server Started: " + iAdd);
      ByteBuffer buffer = ByteBuffer.allocate(1024);
      //receive buffer from client.
      SocketAddress remoteAdd = server.receive(buffer);
      //change mode of buffer
      buffer.flip();
      int limits = buffer.limit();
      byte bytes[] = new byte[limits];
      buffer.get(bytes, 0, limits);
      String msg = new String(bytes);
      System.out.println("Client at " + remoteAdd + "  sent: " + msg);
      server.send(buffer,remoteAdd);
      server.close();
   }
}

उत्पादन

Server Started: localhost/127.0.0.1:8989

ग्राहक: DatagramChannelClient.java

import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.DatagramChannel;

public class DatagramChannelClient {
   public static void main(String[] args) throws IOException {
      DatagramChannel client = null;
      client = DatagramChannel.open();

      client.bind(null);

      String msg = "Hello World!";
      ByteBuffer buffer = ByteBuffer.wrap(msg.getBytes());
      InetSocketAddress serverAddress = new InetSocketAddress("localhost",
        8989);

      client.send(buffer, serverAddress);
      buffer.clear();
      client.receive(buffer);
      buffer.flip();
    
      client.close();
   }
}

उत्पादन

क्लाइंट चलाने से सर्वर पर निम्न आउटपुट प्रिंट होगा।

Server Started: localhost/127.0.0.1:8989
Client at /127.0.0.1:64857  sent: Hello World!