Java NIO Java NIO DatagramChannel
2016-01-19 19:50
441 查看
Java NIO中的DatagramChannel是一个能收发UDP包的通道。因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入。它发送和接收的是数据包。
这个例子打开的 DatagramChannel可以在UDP端口9999上接收数据包。
receive()方法会将接收到的数据包内容复制到指定的Buffer. 如果Buffer容不下收到的数据,多出的数据将被丢弃。
这个例子发送一串字符到”jenkov.com”服务器的UDP端口80。 因为服务端并没有监控这个端口,所以什么也不会发生。也不会通知你发出的数据包是否已收到,因为UDP在数据传送方面没有任何保证。
这里有个例子:
当连接后,也可以使用read()和write()方法,就像在用传统的通道一样。只是在数据传送方面没有任何保证。这里有几个例子:
打开 DatagramChannel
下面是 DatagramChannel 的打开方式:DatagramChannel channel = DatagramChannel.open(); channel.socket().bind(new InetSocketAddress(9999));
这个例子打开的 DatagramChannel可以在UDP端口9999上接收数据包。
接收数据
通过receive()方法从DatagramChannel接收数据,如:ByteBuffer buf = ByteBuffer.allocate(48); buf.clear(); channel.receive(buf);
receive()方法会将接收到的数据包内容复制到指定的Buffer. 如果Buffer容不下收到的数据,多出的数据将被丢弃。
发送数据
通过send()方法从DatagramChannel发送数据,如: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));
这个例子发送一串字符到”jenkov.com”服务器的UDP端口80。 因为服务端并没有监控这个端口,所以什么也不会发生。也不会通知你发出的数据包是否已收到,因为UDP在数据传送方面没有任何保证。
连接到特定的地址
可以将DatagramChannel“连接”到网络中的特定地址的。由于UDP是无连接的,连接到特定地址并不会像TCP通道那样创建一个真正的连接。而是锁住DatagramChannel ,让其只能从特定地址收发数据。这里有个例子:
channel.connect(new InetSocketAddress("jenkov.com", 80));
当连接后,也可以使用read()和write()方法,就像在用传统的通道一样。只是在数据传送方面没有任何保证。这里有几个例子:
int bytesRead = channel.read(buf); int bytesWritten = channel.write(but);
相关文章推荐
- Java NIO ServerSocketChannel
- Java NIO SocketChannel
- 谈Spring的理解
- Java NIO FileChannel
- Java NIO Selector
- java文件复制函数
- 【转】Java中如何遍历Map对
- eclipse 中文乱码
- eclipse汉字太小解决办法
- eclipse中文乱码
- Java NIO 通道之间的数据传输
- Java NIO Scatter/Gather
- POJ 1088 Java:滑雪(动态规划)
- 利用Spring AOP监控方法(二)日志存放位置
- RabbitMQ入门教程 For Java【7】 - Window下的安装与配置
- POJ 1001 Java:求高精度幂
- 出现java.lang.NoClassDefFoundError: net/sf/ezmorph/Morpher错误
- Java多线程(3) Volatile的实现原理
- Spring声明式事务配置管理方法
- myeclipse和输入法冲突的问题