1.BIO
BIO:是传统的javaIO以及部分java.net下部分接口和类。例如,socket,http等,因为网络通信同样是IO行为。传统IO基于字节流和字符流进行操作。提供了我们最熟悉的IO功能,譬如基于字节流的InputStream 和OutputStream.基于字符流的Reader和Writer.
特点:在IO执行的两个阶段都被阻塞住。优点:代码简单,直观。缺点:IO的效率,扩展性存在瓶颈。同步。阻塞
2.NIO
NIO 是一种同步非阻塞的 I/O 模型,在 Java 1.4 中引入了 NIO 框架,对应 java.nio 包,提供了 Channel , Selector,Buffer 等抽象。NIO 中的 N 可以理解为 Non-blocking,不单纯是 New。它支持面向缓冲的,基于通道的 I/O 操作方法。 NIO 提供了与传统 BIO 模型中的 Socket 和 ServerSocket 相对应的 SocketChannel 和 ServerSocketChannel 两种不同的套接字通道实现,两种通道都支持阻塞和非阻塞两种模式。阻塞模式使用就像传统中的支持一样,比较简单,但是性能和可靠性都不好;非阻塞模式正好与之相反。对于低负载、低并发的应用程序,可以使用同步阻塞 I/O 来提升开发速率和更好的维护性;对于高负载、高并发的(网络)应用,应使用 NIO 的非阻塞模式来开发.
特点:程序需要不断的去询问内核是否已经准备好,第一阶段非阻塞,第二阶段阻塞。
NIO的核心是:Channels ,buffers, Selectors.基本上所有的IO在NIO都是从一个Channels开始。
Selector:允许单线程处理多个Channel
NIO的底层使用了操作系统的多路复用。
优点是单线程可以处理多个网络IO.
(1)问题:select,poll,epoll的区别
Select有最大链接数的限制,因为其使用的是数组;poll没有,使用的是链表;
3.AIO
4.BIO,NIO,AIO分析
BIO适用于连接数比较小,且固定的架构。这种方式对服务器资源要求比较高。是1.4以前的唯一选择,直观,简单容易理解。
NIO适用于连接数目多,且连接比较短的架构。比如聊天服务器,编程比较复杂。
AIO适用于连接数目多,且连接比较长的架构。比如:相册服务器,Jdk7以后才支持。