首页 > 基础资料 博客日记
java之BIO NIO AIO
2023-07-29 19:53:20基础资料围观265次
这篇文章介绍了java之BIO NIO AIO,分享给大家做个参考,收藏Java资料网收获更多编程知识
java之BIO NIO AIO
-
BIO: 同步阻塞IO模型:数据的读取写入必须阻塞在一个线程内等待其完成。
-
NIO :同步非阻塞I/O模型
-
定义:同步非阻塞,服务实现模式是一个线程可以处理多个连接,即客户端发送的连接都会注册到多路复用器上,然后进行轮询连接,有I/O请求就处理。
-
三大核心内容:Selector(选择器)、Channel(通道)、Buffer(缓冲区)。
-
selector:用于监听多个Channel的事件,并对检测到的I/O事件进行相应的响应和处理。
-
Channel:双向的,既可以进行读操作,也可以进行写操作。
-
Buffer:本质是个容器、其内部通过一个连续的字节数组存储I/O上的数据。
-
-
AIO:异步非阻塞I/O模型:AIO 也就是 NIO 2,在 Java 7 中引⼊了 NIO 的改进版 NIO 2,它 是异步⾮阻塞的 IO 模型。异步 IO 是基于事件和回调机制实现的,也就是应⽤操作之后会直 接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作
BIO | NIO | AIO | |
---|---|---|---|
IO模型 | 同步阻塞 | 同步非阻塞(多路复用) | 异步非阻塞 |
面向流(Stream) | 面向缓冲区块(Buffer)【效率:块》流】 | ||
应用场景 | 适用连接数目比较小且固定的架构,对服务器要求比较高,并发局限于应用中 | 适用连接数目多且连接比较短的架构,如:聊天服务器,弹幕系统等,编程比较复杂 | 适用连接数目多且连接长的架构,如相册服务器 |
文章来源:https://www.cnblogs.com/hcxss/p/16507994.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:思维导图学《On Java》基础卷
下一篇:Java基础学习-数据类型拓展