这篇文章主要记录一些我个人在学习和项目中,遇到的比较基础的一些知识点,方便自己和大家查看。我将会不断完善更新。
--------------------------------------------------------------------分割线---------------------------------------------------------------------------
阻塞和非阻塞——线程访问资源,对该资源是否准备就绪的一种处理方式
阻塞:线程一直等待资源处理完毕,返回结果。
非阻塞:线程不等待资源处理完毕,他会去请求别的资源。
同步和异步——访问数据的一种机制
同步:主动请求并等待IO通知。
异步:主动请求后处理其他任务,结果通过异步通知逐个返回。
BIO (Block IO)
同步阻塞IO。IO进行读写时,线程被阻塞无法做其他操作,是一种传统简单的模式,但是并发处理能力比较低。并且线程之间访问资源耗时较久,比较依赖网速和带宽。JDK1.4之前都是使用BIO。比如:上厕所的时候,厕所满了,我们主动观察等待空位留出,等有人出来时就去占坑。这就是一种BIO。
NIO (Non-Block IO / New IO)
同步非阻塞IO。Selector主动轮询Channel, 哪一个Channel就绪,Selector就进行相应的请求处理。NIO是JDK1.4之后出现的。比如:上厕所的时候,厕所满了,我们出去抽根烟或者玩会手机,时不时的回厕所看一下,有坑留出的话就去占坑。这就是一种NIO。
AIO (NIO 2.0)
异步非阻塞IO。还是上厕所的例子:和BIO不一样的是,在我们出去抽根烟或者玩会手机的时候,有人释放完坑回来主动通知我们。这就是一种AIO。
异步阻塞IO在平时开发中几乎用不到。即等坑时什么都不干,等有人好后再来通知你。
同步-主动看,
异步-被通知。
常见面试题:
- BIO,NIO,AIO 的区别是什么?
- 什么是同步阻塞BIO?
- 什么是同步非阻塞NIO?
- 什么是异步非阻塞AIO?
==============
Java单例详细说明:https://www.cnblogs.com/zhaoyanjun/p/5652930.html