BIO、AIO、NIO

BIO


Blocking IO:同步阻塞,一个线程一个连接,一个请求就需要一个线程。如果连接不做读写,那么线程就会闲置。线程的开销大。

优点及应用场景:适用于连接数目小且固定的架构。对服务器的资源要求较高,并发局限与应用中。但简单易于理解。

NIO


Non-Blocking IO:同步非阻塞,一个请求一个线程,但连接请求都是先注册到多路复用器上,多路复用器轮询到连接有IO请求时才启动一个线程处理。

在这里插入图片描述
优点及应用场景:适用于连接数目多且连接时间短的架构,如聊天服务器、弹幕系统、分布式系统通信。

三大核心组件:selector、channel、buffer

线程通过selector 来处理多个通道
面向缓冲区编程,channel和client不直接操作,而是通过缓冲区来进行操作。

AIO

Asynchronous I/O:异步非阻塞,一个有效请求一个线程,客户端的IO请求都由OS先完成了再通知服务器去启动线程处理。

优点及应用场景:适用于连接数目比较多且长的架构,如相册服务器。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值