NIO多路复用底层实现原理

Bio演变的NIO的过程

Bio是一个阻塞式的io,不能够支持并发请求访问;可以多线程优化代码

这种方式也存在缺点:如果每个请求过来都使用一个线程,这时候非常浪费CPU的资源。

所以在网络编程服务器中,是否使用单线程提高响应的效率问题,所以nio出现;

public class ServerTcpSocket {
   
static byte[] bytes = new byte[1024];

   
public static void main(String[] args) {
        ExecutorService executorService = Executors.newCachedThreadPool();
       
try {
           
// 1.创建一个ServerSocket连接
           
final ServerSocket serverSocket = new ServerSocket();
           
// 2.绑定端口号
           
serverSocket.bind(new InetSocketAddress(8080));
           
// 3.当前线程放弃cpu资源等待获取数据
           
System.out.println("等待获取数据...");
           
while (true) {
               
final Socket socket = serverSocket.accept();
                executorService.execute(
new Runnable() {
                   
public void run() {
                       
try {
                            System.
out.println("获取到数据...");
                           
// 4.读取数据
                            
int read = socket.getInputStream().read(bytes);
                            String result =
new String(bytes);
                            System.
out.println(result);
                        }
catch (Exception e) {

                        }
                    }
                });

            }
        }
catch (Exception e) {

        }
    }
}

 

 

 

 

NIO非阻塞式代码

public class ServerNioTcpSocket {
   
static ByteBuffer byteBuffer = ByteBuffer.allocate(512);

   
public static void main(String[] args) {
       
try {
           
// 1.创建一个ServerSocketChannel连接
           
final ServerSocketChannel serverSocketChannel = ServerSocketCha

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值