java之BIO NIO AIO

Java网络编程模型
java之BIO NIO AIO
  1. BIO同步阻塞IO模型:数据的读取写入必须阻塞在一个线程内等待其完成。

  2. NIO同步非阻塞I/O模型

    • 定义:同步非阻塞,服务实现模式是一个线程可以处理多个连接,即客户端发送的连接都会注册到多路复用器上,然后进行轮询连接,有I/O请求就处理。

    • 三大核心内容:Selector(选择器)、Channel(通道)、Buffer(缓冲区)。

    • selector:用于监听多个Channel的事件,并对检测到的I/O事件进行相应的响应和处理。

    • Channel:双向的,既可以进行读操作,也可以进行写操作。

    • Buffer:本质是个容器、其内部通过一个连续的字节数组存储I/O上的数据。

  3. AIO异步非阻塞I/O模型:AIO 也就是 NIO 2,在 Java 7 中引⼊了 NIO 的改进版 NIO 2,它 是异步⾮阻塞的 IO 模型。异步 IO 是基于事件和回调机制实现的,也就是应⽤操作之后会直 接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作

BIONIOAIO
IO模型同步阻塞同步非阻塞(多路复用)异步非阻塞
面向流(Stream)面向缓冲区块(Buffer)【效率:块》流】
应用场景适用连接数目比较小且固定的架构,对服务器要求比较高,并发局限于应用中适用连接数目多且连接比较短的架构,如:聊天服务器,弹幕系统等,编程比较复杂适用连接数目多且连接长的架构,如相册服务器
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值