Java 同步/异步IO,阻塞/非阻塞IO

对于IO,有同步,异步,阻塞,非阻塞的分类,最近才稍微对这些分类有一些理解,下面记录一下:

首先,我们需要划分IO,我们对IO操作分为两个步骤,1:程序发出IO请求,2:完成实际IO操作,阻塞、非阻塞是针对第一步划分的,而同步、异步是针对第二部划分的。

阻塞/非阻塞:首先,我觉得应该理解一下什么叫阻塞。一个IO请求,在线程中进行,当这个IO请求没有数据或者没有有效数据拉来完成IO操作,那么这个请求不会结束,而是等待,而这个等待就是阻塞,因为他在等待数据,导致其他IO操作无法进行,就像一个前列腺的男子等着pee,从而使整个厕所阻塞。但是怎么解决这个事情呢,java中NIO库用来解决这个问题,通过buffer,channel,selector使IO请求迅速获得是否可以进行实际操作的信息,无论可不可以,如果数据没有准备好,那么就返回信息没有准备好。然后进行别的io操作。

同步/异步:上面说到过,同步/异步IO的区分是针对完成实际的IO操作,笼统的说,同步IO就是应用程序完成实际的IO操作,而异步IO就是将实际的IO操作交给操作系统去完成,这么说,我自己都很难理解,应用程序完成和操作系统完成有什么区别呢?首先说同步,如果是应用程序本身去完成这个IO操作,那么这个应用程序这个进程就会被阻塞,这里的阻塞和上面的阻塞不同,上面的阻塞和非阻塞IO其实都属于同步IO,因为无论他们在请求时是否阻塞线程,他们的IO操作都是由应用程序进行的.而异步IO就不同了,它将实际IO操作交给操作系统去完成,首先应用程序本身的进程就没有阻塞,其次操作系统能利用的进程很多,等实际IO操作完成之后,通知程序一声就可以了,这样性能就会高于同步IO.

我觉的理解这四个分类首先就要理解IO操作的两个步骤,否则你会认为阻塞/非阻塞/同步/异步 是四个没有交集的分类,但其实同步IO包括了阻塞和非阻塞IO,

我的理解暂时就是这样,如果有了新的理解,再来修改

猜你喜欢

转载自blog.csdn.net/qq_36865108/article/details/82713426