zoukankan      html  css  js  c++  java
  • Java NIO系列教程(九) ServerSocketChannel

    Java NIO系列教程(九) ServerSocketChannel

    Java NIO 中的 ServerSocketChannel 是一个可以监听新进来的 TCP 连接的通道, 就像标准 IO 中的 ServerSocket 一样。ServerSocketChannel 类在 java.nio.channels 包中。

    这里有个例子:

    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    serverSocketChannel.socket().bind(new InetSocketAddress(9999));
    
    while(true){
        SocketChannel socketChannel = serverSocketChannel.accept();
        //do something with socketChannel...
    }
    

    一、打开 ServerSocketChannel

    通过调用 ServerSocketChannel.open() 方法来打开 ServerSocketChannel。如:

    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    

    二、关闭 ServerSocketChannel

    通过调用 ServerSocketChannel.close() 方法来关闭 ServerSocketChannel。如:

    serverSocketChannel.close();
    

    三、监听新进来的连接

    通过 ServerSocketChannel.accept() 方法监听新进来的连接。当 accept() 方法返回的时候,它返回一个包含新进来的连接的 SocketChannel。因此,accept() 方法会一直阻塞到有新连接到达。

    通常不会仅仅只监听一个连接,在 while 循环中调用 accept() 方法。如下面的例子:

    while(true){
        SocketChannel socketChannel = serverSocketChannel.accept();
     
        //do something with socketChannel...
    }
    

    当然,也可以在 while 循环中使用除了 true 以外的其它退出准则。

    四、非阻塞模式

    ServerSocketChannel 可以设置成非阻塞模式。在非阻塞模式下,accept() 方法会立刻返回,如果还没有新进来的连接,返回的将是 null。 因此,需要检查返回的 SocketChannel 是否是 null。如:

    ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
    serverSocketChannel.socket().bind(new InetSocketAddress(9999));
    serverSocketChannel.configureBlocking(false);
    
    while(true){
        SocketChannel socketChannel = serverSocketChannel.accept();
    
        if(socketChannel != null){
            //do something with socketChannel...
        }
    }
    

    转载自并发编程网 – ifeve.com,本文链接地址: Java NIO系列教程(九) ServerSocketChannel

  • 相关阅读:
    WebSocket面试题
    面试题、四
    面试题、三
    面试题、二
    面试题、一
    vue 使用localstorage实现面包屑
    flutter,SliverPersistentHeader实现Tab顶部吸附固定效果
    对flutter中,ExpsionPanel的简单改造
    node.js学习笔记
    PHP和Redis实现在高并发下的抢购及秒杀功能示例详解
  • 原文地址:https://www.cnblogs.com/binarylei/p/9977580.html
Copyright © 2011-2022 走看看