面试-javaIO机制

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以后才支持。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值