-
- 阻塞:
-
非阻塞:
-
BIO
-
BIO同步阻塞IO总结
-
NIO介绍
-
同步非阻塞
-
AIO
| | |
| — | — |
====================================================================
Java IO流是一个庞大的技术体系,其内部提供了很多不同的流, 如: 输入流和输出流,细分下去还有字节流和字符流,甚至还有缓冲流提高 IO 性能,转换流将字节流转换为字符流等等
======================================================================
同步调用请求发送后,调用者将一直等待被调用者返回消息,若无响应则一直等待无法进行后续操作,直至有消息返回
异步调用请求发送后,调用者无需等待消息返回便可进行其他操作,消息会以通知的方式告知调用者
=====================================================================
调用结果返回之前,当前线程会被挂起. 调用线程只有在得到结果之后才会返回
不能立刻得到结果之前,该调用不会阻塞当前线程
==================================================================
BIO就是属于同步阻塞的IO
他在jdk1.4之前,是唯一的选择,
调用发起后, 会阻塞线程, 直到获得到结果
服务端一个线程只能同时处理一个客户端的请求。
基于TCP/IP实现Socket编程
使用的就是BIO, 同步阻塞IO
他的一个线程只能同一时间内 处理一次请求
如何解决这个问题,那就是使用创建多个线程来处理多个客户的请求
==========================================================================
每个客户端需要对应服务端的一个子线程。 所以有多少个客户端, 服务端就需要创建多少个子线程。如果客户端特别多,几万甚至几百万,服务器端就需要有几万甚至几百万的子线程。 由于每个子线程都有自己的独立线程区,这么多子线程可能就产生内存不足等问题。而且这么多的子线程也需要进行调度, 切换, 销毁这也是非常消耗性能的
虽然可以解决一个服务端处理多个客户端,但是因为过多的子线程导致系统资源消耗过多,线程切换导致性能下降也是我们不得不需要考虑的问题
可以使用线程池,在一定程度上提升程序性能
====================================================================
Java 从JDK1.4版本开始推出了NIO模型, 在java.nio包中
NIO称为New IO(新的IO)又称Non-Blocking IO(非阻塞IO)
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
之门!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!