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

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

    • 阻塞:
  • 非阻塞:

  • BIO

  • BIO同步阻塞IO总结

  • 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)

复习的面试资料

这些面试全部出自大厂面试真题和面试合集当中,小编已经为大家整理完毕(PDF版)

  • 第一部分:Java基础-中级-高级

image

  • 第二部分:开源框架(SSM:Spring+SpringMVC+MyBatis)

image

  • 第三部分:性能调优(JVM+MySQL+Tomcat)

image

  • 第四部分:分布式(限流:ZK+Nginx;缓存:Redis+MongoDB+Memcached;通讯:MQ+kafka)

image

  • 第五部分:微服务(SpringBoot+SpringCloud+Dubbo)

image

  • 第六部分:其他:并发编程+设计模式+数据结构与算法+网络

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

进阶学习笔记pdf

  • Java架构进阶之架构筑基篇(Java基础+并发编程+JVM+MySQL+Tomcat+网络+数据结构与算法

image

  • Java架构进阶之开源框架篇(设计模式+Spring+SpringMVC+MyBatis

image

image

image

  • Java架构进阶之分布式架构篇 (限流(ZK/Nginx)+缓存(Redis/MongoDB/Memcached)+通讯(MQ/kafka)

image

image

image

  • Java架构进阶之微服务架构篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)

image

image

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
Dubbo+K8s)**

[外链图片转存中…(img-sa6K4Typ-1714411537669)]

[外链图片转存中…(img-9Rn94mF0-1714411537669)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值