参考
-
一文让你彻底理解 Java NIO 核心组件
https://segmentfault.com/a/1190000017040893 -
Java NIO浅析
https://tech.meituan.com/2016/11/04/nio.html
理解
- 传统的Java IO 通过开启多个线程的方式解决IO过程中一个IO流无法读写数据时,CPU资源的空闲.即一个线程对应的IO阻塞,则将该线程挂起. 让另一个线程跑起来去工作.
- 传统的Java IO 在有非常大量的请求连接的时候(如大规模的服务端的请求连接) 会创建很多的线程, 这样大量的线程会耗费很多内存资源(线程栈); 同时频繁的线程切换也会消耗很多系统资源.
- 基于上述问题, 有了Java NIO, 使用一个线程去处理大量的连接请求, 使用Channel去管理每一个IO流, 并将Channel注册到Selector; Selector监听Channel可以读/写事件的发生,然后告知线程进行处理.