首页 > 基础资料 博客日记

java之BIO NIO AIO

2023-07-29 19:53:20基础资料围观265

这篇文章介绍了java之BIO NIO AIO,分享给大家做个参考,收藏Java资料网收获更多编程知识

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 是基于事件和回调机制实现的,也就是应⽤操作之后会直 接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作

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

文章来源:https://www.cnblogs.com/hcxss/p/16507994.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!

标签:

相关文章

本站推荐

标签云