zoukankan      html  css  js  c++  java
  • Java NIO系列教程(十) Java NIO DatagramChannel

    Java NIO中的DatagramChannel是一个能收发UDP包的通道。因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入。它发送和接收的是数据包。

    打开 DatagramChannel

    下面是 DatagramChannel 的打开方式:

    1 DatagramChannel channel = DatagramChannel.open();
    2 channel.socket().bind(new InetSocketAddress(9999));

    这个例子打开的 DatagramChannel可以在UDP端口9999上接收数据包。

    接收数据

    通过receive()方法从DatagramChannel接收数据,如:

    1 ByteBuffer buf = ByteBuffer.allocate(48);
    2 buf.clear();
    3 channel.receive(buf);

    receive()方法会将接收到的数据包内容复制到指定的Buffer. 如果Buffer容不下收到的数据,多出的数据将被丢弃。

    发送数据

    通过send()方法从DatagramChannel发送数据,如:

    1 String newData = "New String to write to file..." + System.currentTimeMillis();
    2  
    3 ByteBuffer buf = ByteBuffer.allocate(48);
    4 buf.clear();
    5 buf.put(newData.getBytes());
    6 buf.flip();
    7  
    8 int bytesSent = channel.send(buf, new InetSocketAddress("jenkov.com"80));

    这个例子发送一串字符到”jenkov.com”服务器的UDP端口80。 因为服务端并没有监控这个端口,所以什么也不会发生。也不会通知你发出的数据包是否已收到,因为UDP在数据传送方面没有任何保证。

    连接到特定的地址

    可以将DatagramChannel“连接”到网络中的特定地址的。由于UDP是无连接的,连接到特定地址并不会像TCP通道那样创建一个真正的连接。而是锁住DatagramChannel ,让其只能从特定地址收发数据。

    这里有个例子:

    1 channel.connect(new InetSocketAddress("jenkov.com"80));

    当连接后,也可以使用read()和write()方法,就像在用传统的通道一样。只是在数据传送方面没有任何保证。这里有几个例子:

    1 int bytesRead = channel.read(buf);
    2 int bytesWritten = channel.write(but);
  • 相关阅读:
    【新阁教育】爱普生机器人建立工具坐标系教程
    BPF CO-RE 示例代码解析
    gRPC Load Balancing
    Linux Clone函数
    高性能 Nginx HTTPS 调优
    内网渗透测试:内网横向移动基础总结
    Python 运算符
    华为云-容器引擎CCE-部署Nginx应用
    华为云-云容器引擎(CCE)-高危操作及解决方案
    周杰伦新歌《说好不哭》上线,程序员哭了......
  • 原文地址:https://www.cnblogs.com/daimzh/p/12854478.html
Copyright © 2011-2022 走看看