解释什么是异步非阻塞?

在IO和网络编程中,我们经常看到几个概念:同步、异步、阻塞、非阻塞。

同步和异步

  同步和异步是针对应用程序和内核的交互而言的,同步指的是用户进程触发IO 操作并等待或者轮询的去查看IO 操作是否就绪,而异步是指用户进程触发IO 操作以后便开始做自己的事情,而当IO 操作已经完成的时候会得到IO 完成的通知。

阻塞和非阻塞

  阻塞和非阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同方式,说白了是一种读取或者写入操作方法的实现方式,阻塞方式下读取或者写入函数将一直等待,而非阻塞方式下,读取或者写入方法会立即返回一个状态值。

 

理解方式

  乍一看这四个概念的解释会瞬间感到头大,也经常讲同步异步等同于阻塞非阻塞,其实,区分他们非常简单。

  同步异步与阻塞非阻塞的主要区别是针对对象不同。

 

  同步异步是针对调用者来说的,调用者发起一个请求后,一直干等被调用者的反馈就是同步,不必等去做别的事就是异步。

  阻塞非阻塞是针对被调用者来说的,被调用者收到一个请求后,做完请求任务后才给出反馈就是阻塞,收到请求直接给出反馈再去做任务就是非阻塞。

 

在公交站等公交

  对调用者-乘客而言:

  1,一直干望着公交来的方向,就是同步。

  2,不望着公交来的方向,掏出笔记本改bug,听公交站广播是否到车,就是异步。

  对被动用者-公交系统而言:

  1,公交站有广播的就是非阻塞的。

  2,公交站没有广播的就是阻塞的。

posted @ 2019-12-19 04:06  Mr_Riven  阅读(6698)  评论(0编辑  收藏  举报