共计 373 个字符,预计需要花费 1 分钟才能阅读完成。
在学习 Java NIO 的过程中,我一直理解不了 Java NIO 是怎么用来实现高并发的服务器的,网上给出的例子里,基本上没有多少说到这一点的,Tomcat,Jetty 这些的源码又太庞大了,导致我无从下手。
后来搜了下才发现,JDK 自带了一个 httpserver 的实现,看了下代码,非常简洁,非常规范,一下子就让我搞懂了 Java NIO 是怎么实现高并发的了。
NIO 是同步非阻塞模型,同步是指用 NIO 读取数据,需要你的线程一直在运行着,直到数据读写完毕。非阻塞是指监听通道的时候是非阻塞的,比如向通道询问有没有数据可读的时候,可以马上就返回有或者没有。如果有数据,你的线程就可以去处理读数据这部分的逻辑;如果没有数据,你的线程可以去忙其他的事情,这样子单个线程的处理能力就会高很多,不用总是等着数据。
在 jdk 的 httpserver 里,处理请求的过程大致如下图:
正文完