Java Web NIO

     在非阻塞IO(Nonblocking IO,NIO)出现之前,Java是通过传统的Socket来实现网络通信功能。以服务端为例,传统的Socket基本流程如下:


       如果客户端没有对服务端发起连接请求,调用accept时会阻塞(阻塞指的是暂停执行一个线程以等待某个条件发生,例如某资源就绪)。如果连接成功但数据没有准备好时,调用read时会阻塞。如果处理多个连接,采用多线程方式时,因为每个线程都有自己的栈空间,而且阻塞会导致大量线程进行上下文切换,使程序运行效率低下,所以jdk 1.4中引入NIO来解决这个问题。

       NIO通过Selector、Channel和Buffer实现了非阻塞的IO操作,其实现原理图如下:


它采用了Reactor(反应器)设计模式,与Observer(观察者)设计模式类似,但后者只能处理一个事件源,前者可以处理多个事件源。

  在上图中,Channel可以看成一个双向的非阻塞的通道,在通道两边可以执行数据的读写操作。Selector采用了复用和解复用的方式即可以把多个流合并成一个流或者把一个流分成多个流,使得一个线程能管理多个通道,类似于一个观察者。在实现时,把需要处理的Channel的IO事件(例如connect、read或write)注册给Selector。

  Selector内部实现原理:

  轮询访问所有注册的Channel,当轮询到一个Channel有注册的事件发生(例如有数据来了),通过传回SelectionKey的方式来通知开发者进行Channel的数据读写操作。其中,由SelectionKey类表示的Key封装了一个特定Channel和一个特定的Selector之间的关系。

  采用轮询方式在处理多线程请求时不需要上下文切换,而采用多线程的实现方式在线程之间切换时需要上下文切换以及压栈与弹栈操作。因此,NIO有较高的执行效率。

  Buffer用来保存数据,既可以保存从Channel中读取的数据,又可以保存通过Channel发送的数据。Java提供了多种不同类型的Buffer,例如ByteBuffer、CharBuffer等,通过Buffer可以简化开发者对流数据的管理。

  综上所述,与传统的Socket方式相比,因为NIO采用了非阻塞方式,所以在处理大量并发请求时效率更高。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值