Java NIO理解总结

参考

  1. 一文让你彻底理解 Java NIO 核心组件
    https://segmentfault.com/a/1190000017040893

  2. Java NIO浅析
    https://tech.meituan.com/2016/11/04/nio.html

理解

  1. 传统的Java IO 通过开启多个线程的方式解决IO过程中一个IO流无法读写数据时,CPU资源的空闲.即一个线程对应的IO阻塞,则将该线程挂起. 让另一个线程跑起来去工作.
  2. 传统的Java IO 在有非常大量的请求连接的时候(如大规模的服务端的请求连接) 会创建很多的线程, 这样大量的线程会耗费很多内存资源(线程栈); 同时频繁的线程切换也会消耗很多系统资源.
  3. 基于上述问题, 有了Java NIO, 使用一个线程去处理大量的连接请求, 使用Channel去管理每一个IO流, 并将Channel注册到Selector; Selector监听Channel可以读/写事件的发生,然后告知线程进行处理.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值