Java NIO中的DatagramChannel是一个能收发UDP包的通道。
操作步骤:
  1)打开 DatagramChannel
  2)接收/发送数据

同样它也支持NIO的非阻塞模式操作,例如:

public static void main(String[] args){
new Thread(new Runnable() {
@Override
public void run() {
server();
}
}).start(); new Thread(new Runnable() {
@Override
public void run() {
client();
}
}).start();
} // udp,非阻塞io,客户端
public static void client(){
DatagramChannel datagramChannel = null;
try {
// 1.获取通道
datagramChannel = DatagramChannel.open();
// 2.置为非阻塞模式
datagramChannel.configureBlocking(false);
// 3.分配缓冲区
ByteBuffer byteBuffer = ByteBuffer.allocate(1024); while (true) {
Thread.sleep(3000);
// 4.向缓冲区放数据
byteBuffer.put(("时间:"+CommonUtil.getDateTime()+",编号:"+UUID.randomUUID().toString()).getBytes());
byteBuffer.flip();
// 5.通道向服务端发送
datagramChannel.send(byteBuffer, new InetSocketAddress("127.0.0.1", 2787));
byteBuffer.clear();
}
} catch (Exception ex) {
ex.printStackTrace();
} finally{
if (datagramChannel!=null) {
try {
datagramChannel.close();
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
}
// udp,非阻塞io,服务端
public static void server(){
DatagramChannel datagramChannel = null;
try {
// 1.获取通道
datagramChannel = DatagramChannel.open();
// 2.置为非阻塞模式
datagramChannel.configureBlocking(false);
// 3.绑定监听端口
datagramChannel.bind(new InetSocketAddress(2787));
// 4.获取选择器
Selector selector = Selector.open();
// 5.通道注册选择器
datagramChannel.register(selector, SelectionKey.OP_READ);
// 5.获取选择器上的已选择的键
while (selector.select()>0) {
Iterator<SelectionKey> it = selector.selectedKeys().iterator();
while (it.hasNext()) {
SelectionKey skey = it.next();
// 7.判断当前键的监听事件
if (skey.isConnectable()) {
System.out.println("connectable");
}else if (skey.isAcceptable()) {
System.out.println("acceptable");
}else if (skey.isReadable()) {
System.out.println("readable");
ByteBuffer mBuffer = ByteBuffer.allocate(1024);
datagramChannel.receive(mBuffer);
mBuffer.flip();
System.out.println("receive:"+new String(mBuffer.array(), 0, mBuffer.array().length));
mBuffer.clear();
}
}
it.remove();
}
} catch (Exception ex) {
ex.printStackTrace();
} finally{
if (datagramChannel!=null) {
try {
datagramChannel.close();
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
}

结果

readable
receive:时间:2017-01-01 19:01:46,编号:63feeb8f-7ead-4e2f-a65b-8471ef3940e3
readable
receive:时间:2017-01-01 19:01:46,编号:63feeb8f-7ead-4e2f-a65b-8471ef3940e4
readable
receive:时间:2017-01-01 19:01:46,编号:63feeb8f-7ead-4e2f-a65b-8471ef3940e5
readable
receive:时间:2017-01-01 19:01:46,编号:63feeb8f-7ead-4e2f-a65b-8471ef3940e6

NIO之DatagramChannel的更多相关文章

  1. Java基础知识强化之IO流笔记81:NIO之 DatagramChannel

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

  2. Java NIO -- DatagramChannel

    Java NIO中的DatagramChannel是一个能收发UDP包的通道.操作步骤:打开 DatagramChannel接收/发送数据 代码举例: package com.soyoungboy.n ...

  3. DatagramChannel

    DatagramChannel 最后一个socket通道是DatagramChannel.正如SocketChannel对应Socket,ServerSocketChannel对应ServerSock ...

  4. An NIO.2 primer--reference

    Part 1: The asynchronous channel APIs The More New I/O APIs for the Java™ Platform (NIO.2) is one of ...

  5. 使用JAVA NIO实现的UDP client和server

    //////////////////////////////////////////////////////////////////////////////////////////////////// ...

  6. JAVA NIO学习三:NIO 的非阻塞式网络通信

    紧接着上一章,我们继续来研究NIO,上一章中我们讲了NIO 中最常见的操作即文件通道的操作,但实际上NIO的主要用途还是在于网络通信,那么这个时候就会涉及到选择器,这一章我们就会对其进行讲解操作. 一 ...

  7. JAVA NIO工作原理及代码示例

    简介:本文主要介绍了JAVA NIO中的Buffer, Channel, Selector的工作原理以及使用它们的若干注意事项,最后是利用它们实现服务器和客户端通信的代码实例. 欢迎探讨,如有错误敬请 ...

  8. NIO的初步入门

    NIO java NIO简介 Java NIO 简介 是从java1.4版本开始引入的一个新的IO AP可以替代标准java  IO API NIO与原来的IO有同样的作用和目的,但是使用方式完全不同 ...

  9. 理解Java的NIO

    同步与阻塞 同步和异步是针对应用程序和内核的交互而言的. 同步:执行一个操作之后,进程触发IO操作并等待(阻塞)或者轮询的去查看IO的操作(非阻塞)是否完成,等待结果,然后才继续执行后续的操作. 异步 ...

随机推荐

  1. 7、Django实战第7天:用form实现登录

    Django提供了form对表单进行验证,比如今天要完成的限定登录的时候用户名和密码不能为空,通过这个操作,数据进入到数据库查询之前,我们就可以过滤很多错误,避免不必要的查询. 在users目录下新建 ...

  2. ( 转 ) mysql复合索引、普通索引总结

    对于复合索引:Mysql从左到右的使用索引中的字段,一个查询可以只使用索引中的一部份,但只能是最左侧部分.例如索引是key index (a,b,c). 可以支持a | a,b| a,b,c 3种组合 ...

  3. 【块状树】【树链剖分】bzoj1036 [ZJOI2008]树的统计Count

    很早之前用树链剖分写过,但是代码太长太难写,省选现场就写错了. #include<cstdio> #include<algorithm> #include<cstring ...

  4. 【费用流】bzoj2661 [BeiJing wc2012]连连看

    将每个数拆点,互相连边,然后满足条件的数对之间互相连边,跑最大费用流,答案是流量和费用分别除以2. 一定要i->j.j->i都连上,否则可能会出现一个数在一边被选择了,在另一边的另一个匹配 ...

  5. 求一个整数个位数之和 Exercise06_02

    import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年下半年 * 题目:求一个整数个位数之和 * */ public class Exercise ...

  6. "__doPostBack”未定义的解决办法(转载)

    "__doPostBack”未定义,在IE下调试错误: 问题是服务器版的.Net40的补丁没有打上,ASP.NET 可能无法辨识出一些浏览器的最新版本,还会经常把它们看做是低级的浏览器,不支 ...

  7. 消息队列系列(四):Rabbitmq常用命令行

    目录:安装目录下的 ./sbin rabbitmqctl [-n node] [-t timeout] [-q] {command} [command options…] http://www.rab ...

  8. mysql 中查询一个字段是否为null的sql

    查询mysql数据库表中字段为null的记录: select * 表名 where 字段名 is null 查询mysql数据库表中字段不为null的记录: select * 表名 where 字段名 ...

  9. httpd 服务的两个节点的HA

    实验目的是:实现两个节点的http和nfs服务的HA集群. 实现条件:准备两个节点.node1,node2作为HA1,HA2提供集群服务.在node1和node2分别按照httpd服务.挂载nfs服务 ...

  10. FL2440 rt3070模块ap模式移植

    ---------------------------------------------------------------------------------------------------- ...