《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
-
- 阻塞:
-
非阻塞:
-
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)
复习的面试资料
这些面试全部出自大厂面试真题和面试合集当中,小编已经为大家整理完毕(PDF版)
- 第一部分:Java基础-中级-高级
- 第二部分:开源框架(SSM:Spring+SpringMVC+MyBatis)
- 第三部分:性能调优(JVM+MySQL+Tomcat)
- 第四部分:分布式(限流:ZK+Nginx;缓存:Redis+MongoDB+Memcached;通讯:MQ+kafka)
- 第五部分:微服务(SpringBoot+SpringCloud+Dubbo)
- 第六部分:其他:并发编程+设计模式+数据结构与算法+网络
进阶学习笔记pdf
- Java架构进阶之架构筑基篇(Java基础+并发编程+JVM+MySQL+Tomcat+网络+数据结构与算法)
- Java架构进阶之开源框架篇(设计模式+Spring+SpringMVC+MyBatis)
- Java架构进阶之分布式架构篇 (限流(ZK/Nginx)+缓存(Redis/MongoDB/Memcached)+通讯(MQ/kafka))
- Java架构进阶之微服务架构篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
Dubbo+K8s)**
[外链图片转存中…(img-sa6K4Typ-1714411537669)]
[外链图片转存中…(img-9Rn94mF0-1714411537669)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!