本文主要是介绍【java】BIO、NIO、AIO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
BIO
同步阻塞IO,使用BIO读取数据时,线程会阻塞住,并且需要线程主动去查询是否有数据可读,并且需要处理完一个Socket之后才能处理下一个Socket
在这种模型下,每个 I/O 操作都会阻塞当前线程,直到操作完成才会返回。这意味着当一个线程执行 I/O 操作时,它会被阻塞,无法执行其他任务,直到 I/O 操作完成。
优点:实现简单,易于理解和使用,
缺点:在高并发环境下性能较差,因为它会导致大量线程阻塞,消耗大量系统资源。
Netty
一个基于NIO的异步网络通信框架,性能高,封装了原生NIO编码的复杂度,开发者可以直接使用Netty来开发高效率的各种网络服务器,并且编码简单。
vs Tomcat
Tomcat是一个Web服务器,是一个Servlet容器,基本上Tomcat内部只会运行Servlet程序,并处理HTTP请求,而Netty封装的是底层IO模型,关注的是网络数据的传输,而不关心具体的协议,可定制性更高。
特点:
1.异步、NIO的网络通信框架
2.高性能
3.高扩展,高定制性
4.易用性
NIO
同步非阻塞IO,使用NIO读取数据时,线程不会阻塞,但需要线程主动的去查询是否有IO事件
它提供了 Channel 和 Buffer 的抽象,以及 Selector 的多路复用机制。
在 NIO 中,一个线程可以管理多个 Channel,通过 Selector 监听多个 Channel 的事件,当某个 Channel 有 I/O 事件发生时,线程会被唤醒处理该事件,这样一个线程可以处理多个并发连接,提高了系统的吞吐量和性能。
AIO
也叫做NIO2.0,异步非阻塞IO,使用AIO读取数据时,线程不会阻塞,并且当有数据可读时会通知给线程,不需要线程主动去查询
它基于事件和回调机制,相对于 NIO 更进一步地解放了线程,使得一个线程可以管理多个 I/O 操作。
在 AIO 中,I/O 操作不会阻塞当前线程,而是在完成后通过回调通知应用程序,从而实现了真正的异步非阻塞 I/O。
这篇关于【java】BIO、NIO、AIO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!