BIO、NIO、AIO的简单个人理解,同步异步和阻塞非阻塞的简单理解

什么是io

Java IO流是一个庞大的技术体系,其内部提供了很多不同的流, 如: 输入流和输出流,细分下去还有字节流和字符流,甚至还有缓冲流提高 IO 性能,转换流将字节流转换为字符流等等

什么是同步异步

同步:

同步调用请求发送后,调用者将一直等待被调用者返回消息,若无响应则一直等待无法进行后续操作,直至有消息返回

异步:

异步调用请求发送后,调用者无需等待消息返回便可进行其他操作,消息会以通知的方式告知调用者

阻塞与非阻塞

阻塞:

调用结果返回之前,当前线程会被挂起. 调用线程只有在得到结果之后才会返回

非阻塞:

不能立刻得到结果之前,该调用不会阻塞当前线程

BIO

BIO就是属于同步阻塞的IO
他在jdk1.4之前,是唯一的选择,

调用发起后, 会阻塞线程, 直到获得到结果
服务端一个线程只能同时处理一个客户端的请求。

基于TCP/IP实现Socket编程
使用的就是BIO, 同步阻塞IO

他的一个线程只能同一时间内 处理一次请求
如何解决这个问题,那就是使用创建多个线程来处理多个客户的请求
在这里插入图片描述

BIO同步阻塞IO总结

每个客户端需要对应服务端的一个子线程。 所以有多少个客户端, 服务端就需要创建多少个子线程。如果客户端特别多,几万甚至几百万,服务器端就需要有几万甚至几百万的子线程。 由于每个子线程都有自己的独立线程区,这么多子线程可能就产生内存不足等问题。而且这么多的子线程也需要进行调度, 切换, 销毁这也是非常消耗性能的

虽然可以解决一个服务端处理多个客户端,但是因为过多的子线程导致系统资源消耗过多,线程切换导致性能下降也是我们不得不需要考虑的问题

可以使用线程池,在一定程度上提升程序性能

NIO介绍

Java 从JDK1.4版本开始推出了NIO模型, 在java.nio包中
NIO称为New IO(新的IO)又称Non-Blocking IO(非阻塞IO)
NIO的特性就是同步非阻塞IO模型

同步非阻塞

在nio中同步阻塞指定是, 调用发起后, 不会阻塞线程, 等待获得结果
服务端的一个线程可以处理多个客户端

使用nio解决了使用BIO服务端创建过多子线程产生内存不足, 这么多的子线程也需要进行调度, 切换, 销毁也是非常消耗性能的问题

在这里插入图片描述

AIO

AIO(asynchronous):异步非阻塞IO。
在执行时,当前线程内不会阻塞。而且也不需要多线程就可以实现多客户端访问。
AIO是从Java 7 开始出现的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DNCS高级工程师

你的创作是我打赏的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值