1 概述
NIO 2.0 引入了新的异步通道概念,并提供了异步文件通道和异步套接字通道的实现。异步通道提供以下两种方式获取操作结果。
1、通过java.util.concurrent.Future类来表示异步操作的结果;
2、在执行异步操作的时候传入一个java.nio.channels
CompletionHandler接口的实现类作为操作完成的回调。
NIO2.0 的异步套接字通道是真正的异步非阻塞的时间驱动I/O(AIO)。它不需要通过多路复用器对注册的通道进行轮询操作即可实现异步读写,从而简化了NIO的编程模型。
2 AIO创建TimeServer
TimeServerAIO.java 代码如下:
public class TimeServerAIO {
public static void main(String[] args) {
int port = 8080;
AsyncTimeServerHandler timeServerHandler = new AsyncTimeServerHandler(port);
new Thread(timeServerHandler,"AIO-AsyncTimeServerHandler-001").start();
}
}
AsyncTimeServerHandler.java 代码如下:
public class AsyncTimeServerHandler implements Runnable{
private int port;
CountDownLatch latch;
AsynchronousServerSocketChannel serverSocketChannel;
public AsyncTimeServerHandler(int port){
this.port = port;
try {
serverSocketChannel = AsynchronousServerSocketChannel.open();
serverSocketChannel.bind(new InetSocketAddress(port));
System.out.println("TimeServer 启动,端口号是:"+port);
}catch (IOException e){
e.printStackTrace();
}
}
@Override
public void run(){
latch = new CountDownLatch(1);
doAccept();
try {
latch.await();
}catch (InterruptedException e){
e.printStackTrace();
}
}
public void doAccept(){
serverSocketChannel.accept(this,new AcceptCompletionHandler());
}
}
重点对AsyncTimeServerHandler.java分析。在构造方法中,首先创建一个异步的服务端通道AsynchronousServerSocketChannel,然后调用它的bind方法绑定监听端口。如果端口合法且没被占用,则绑定成功。
在线程run方法中,对CountDownLatch对象进行初始化,它的作用是在完成一组正在执行的操作之后,允许当前的线程一直阻塞。在本例中,让线程在此阻塞,防止服务端执行完退出。在实际项目应用中,不需要启动独立的线程来处理AsynchronousServerSocketChannel。这里仅仅是个演示。
doAccept方法用于接受客户端的连接,由于是异步操作,可以传递一个CompletionHandler<AsynchronousServerSocketChannel,? super A>类型的handler实例接收accept操作成功的通知消息。在本例中,通过AcceptCompletionHandler实例作为handle来接受通知消息。
AcceptCompletionHandler.java 代码如下
public class AcceptCompletionHandler implements CompletionHandler<AsynchronousSocketChannel,AsyncTimeServerHandler> {
@Override
public void completed(Async