十二、Java NIO DatagramChannel
2021-01-18 04:12
标签:操作 没有 com ddr href 发送数据 open() htm byte https://www.cnblogs.com/lay2017/p/12901123.html DatagramChannel是一个可以从UDP连接上发送和接收数据包的通道。和TCP不同,UDP是一种不可靠的无连接协议因此我们对DatagramChannel的读写操作就无法直接照搬SocketChannel的做法。 示例代码开启了一个DatagramChannel,并且绑定到了9999端口上,可以建立UDP连接。 receive方法将会把数据拷贝到buffer中,如果buffer的容量不足以包含所有的数据,那么超出的数据将会丢失。 示例代码向jenkov.com服务器的80端口上发送UDP数据包,但是发送成功与否你无法知道,UDP也没有机制来保证数据传递过程。 DatagramChannel一样可以连接到指定地址 连接以后,你就可以执行read和write操作,但是数据是否送达其实无法保证 十二、Java NIO DatagramChannel 标签:操作 没有 com ddr href 发送数据 open() htm byte 原文地址:https://www.cnblogs.com/lay2017/p/12915206.html所有文章
正文
打开一个DatagramChannel
DatagramChannel channel = DatagramChannel.open();
channel.socket().bind(new InetSocketAddress(9999));
接收数据
ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
channel.receive(buf);
发送数据
String newData = "New String to write to file..." + System.currentTimeMillis();
ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
buf.put(newData.getBytes());
buf.flip();
int bytesSent = channel.send(buf, new InetSocketAddress("jenkov.com", 80));
连接到指定地址
channel.connect(new InetSocketAddress("jenkov.com", 80));
int bytesRead = channel.read(buf);
int bytesWritten = channel.write(buf);
上一篇:1282. 用户分组(贪心算法)