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

来源:互联网 发布:clean my mac好用吗 编辑:程序博客网 时间:2024/05/17 01:39
      整体来说,同步是两个对象之间的关系,而阻塞是一个对象的状态。其次,同步就是两种东西通过一种机制实现步调一致,异步是两种东西不必步调一致。

一、同步调用与异步调用:
      在用在调用场景中,无非是对调用结果的不同处理。
      我理解同步调用就是调用一但返回,就能知道结果,而异步是返回时不一定知道结果,还得通过其他机制来获知结果,如:
  • 状态
  • 通知
  • 回调函数
      这里的同步调用
  1. 调用可能一直阻塞(阻塞在消息处理过程,等待消息处理完成)住,直到返回正确的结果。
  2. 调用不会阻塞而是立即返回,但是立即返回的可能是失败的结果。
      所以:同步调用的过程可以是阻塞的,也可以是非阻塞的。它的调用结果是直接由调用的函数返回的。
      这里的异步调用
            调用过程会立即返回不阻塞,但是有时候却拿不到结果(如selector.select()不管是否有注册的事件发生都会立即返回数目,除非设置了超时参数);有时候是收到消息通知后由回调函数获取调用的结果,而等待消息通知的过程中会被阻塞住(wait/notify阻塞或死循环阻塞,前者不占用CPU时间,后者会占用CPU时间),比如Java NIO的Reactor机制,虽然selector.select过程不阻塞立即返回,但是却要放在一个whiel(ture)死循环中一直等待消息通知,直到有注册的事件发生再调用回调函数进行处理,处理过程还是同步的。宁外一种AIO,真正的异步IO,等待通知过程由系统中断机制实现,等待过程也不阻塞。
      所以:异步调用的过程是不阻塞的,但是等待消息通知过程可能会阻塞住(专门有人帮你等消息,然后通知你,这个notifier专门负责帮很多人等消息,然后通知他们,这就是社会分工,这样用notifier一个人的时间,解放了很多人的时间,从而提高整体的工作效率),消息处理过程还是同步的,该读写多久就是多久,偷不了懒的。异步调用会立即返回,返回的结果是消息通知,真正的结果(消息)一般是在回调函数中获取。
为什么需要异步调用:
      异步调用可以使用多线程来充分利用多核机器的处理能力,可在硬件环境不改变的情况下适当的增加软件系统的吞吐量。

二、同步线程与异步线程:
  • 同步线程:即两个线程步调要一致,要相互协商。两个线程的运行进度各不相同,怎么才能步调一致呢?我们直观的理解就是,快的等慢的呗!快的阻塞一下等到慢的步调一致即可。
  • 异步线程:步调不用一致,各自按各自的步调运行,不受另一个线程的影响。
      同步是指两个线程的运行是相关的,其中一个线程可能要阻塞等待另外一个线程的运行;异步的意思是两个线程毫无相关,自己运行自己的。

三、同步通信与异步通信:
      这里的同步和异步是指:发送方和接收方是否协调步调一致!
  • 同步通信是指:发送方和接收方通过一定机制,实现收发步调协调。如:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式
  • 异步通信是指:发送方的发送不管接收方的接收状态,如:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式。
      阻塞和非阻塞就比较容易理解了,没有上面那么多场景,阻塞就是这个事情阻到这儿了,不能继续往下干事了,非阻塞就是这个事情不会阻碍你继续干后面的事情。
阻塞可以是实现同步的一种手段!例如两个东西需要同步,一旦出现不同步情况,我就阻塞快的一方,使双方达到同步。

REF-1:http://blog.chinaunix.net/uid-21411227-id-1826898.html
REF-2:http://blog.chinaunix.net/uid-26000296-id-3754118.html
REF-3:http://www.cnblogs.com/albert1017/p/3914149.html
0 0
原创粉丝点击