【Java.NIO】API —— Channel接口 —— DatagramChannel类

java.nio.channels
public abstract class DatagramChannel extends AbstractSelectableChannel implements ByteChannel, ScatteringByteChannel, GatheringByteChannel, MulticastChannel


DatagramChannel是一个能收发UDP包的通道

因为UDP是无连接的网络协议,所以不能向其他通道那样读取和写入,它发送和接受的是数据包。



打开DatagramChannel

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



接收数据

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

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

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



发送数据

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

String newData = ... ...

ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
buf.put(newData.getBytes());
buf.flip();

int bytesSent = channel.sned(buf, new InetSocketAddress("..com", 80));




连接到特定的地址

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

channel.connect(new InetSocketAddress("...com", 80));

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



你可能感兴趣的:(java.nio)