Java NIO中的 ServerSocketChannel 是一个能够监听新进来的TCP链接的通道, 就像标准IO中的ServerSocket同样。ServerSocketChannel类在 java.nio.channels包中。java
这里有个例子:socket
查看源代码 打印帮助spa
01 |
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); |
03 |
serverSocketChannel.socket().bind( new InetSocketAddress( 9999 )); |
06 |
SocketChannel socketChannel = |
07 |
serverSocketChannel.accept(); |
09 |
//do something with socketChannel... |
打开 ServerSocketChannel
经过调用 ServerSocketChannel.open() 方法来打开ServerSocketChannel.如:code
查看源代码 打印帮助server
1 |
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); |
关闭 ServerSocketChannel
经过调用ServerSocketChannel.close() 方法来关闭ServerSocketChannel. 如:get
查看源代码 打印帮助it
1 |
serverSocketChannel.close(); |
监听新进来的链接
经过 ServerSocketChannel.accept() 方法监听新进来的链接。当 accept()方法返回的时候,它返回一个包含新进来的链接的 SocketChannel。所以, accept()方法会一直阻塞到有新链接到达。io
一般不会仅仅只监听一个链接,在while循环中调用 accept()方法. 以下面的例子:table
查看源代码 打印帮助循环
2 |
SocketChannel socketChannel = |
3 |
serverSocketChannel.accept(); |
5 |
//do something with socketChannel... |
固然,也能够在while循环中使用除了true之外的其它退出准则。
非阻塞模式
ServerSocketChannel能够设置成非阻塞模式。在非阻塞模式下,accept() 方法会马上返回,若是尚未新进来的链接,返回的将是null。 所以,须要检查返回的SocketChannel是不是null.如:
查看源代码 打印帮助
01 |
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); |
03 |
serverSocketChannel.socket().bind( new InetSocketAddress( 9999 )); |
04 |
serverSocketChannel.configureBlocking( false ); |
07 |
SocketChannel socketChannel = |
08 |
serverSocketChannel.accept(); |
10 |
if (socketChannel != null ){ |
11 |
//do something with socketChannel... |