zoukankan      html  css  js  c++  java
  • 同步与异步、阻塞与非阻塞的理解

     

    http://www.zhihu.com/question/19732473

     


    本质都是为了提高效率为目的

    我做一件事情,请求外部协助。外部还没响应结果,我要怎么办,一种办法是,我一直等着对方给我答复结果。另外一种是,对方主动通知我。这是同步和异步的区别。

    比如水壶,有没有主动报警(当水开了时)的机制。

     

    而我那个时候在干嘛,我可以去干别的工作,这种就是阻塞还是非阻塞。

     

    阻塞指的是调用者。异步一般是非阻塞模式。

     

    同步,关注的是调用者,调用者自己要不要定期去看返回结果(烧开水的人要不要定去看水壶里的水是否开)。

     

    如果不需要看,那么就是被调用者主动通知调用者(水壶自动报警通知人),这种情况,永远是异步。

     

    同步,异步关注的是通信状态:调用者和被调用者相互如何通信。是同步通知,还是异步通知?

     

     

     

     

    阻塞,关注的是,等待时能不能干别的事情:调用者此时没有得到调用结果前,能不能去干别的事情。能去干别的事情,就是非阻塞。

     

    同步一般都是阻塞模式。因为要卡着等待结果嘛,不能干其他事情。

     

     --------------------------------------地铁上思考

     

    现实生活中很多类似的例子。异步、非阻塞,都是对原来方式的提高效率。所以,应该是从现实生活中借鉴过来的

     

    那有没有,同步非阻塞模式呢?

    有!

    现实生活中,人等待水壶烧开水。

    人可以等着水烧开,什么都不做,也可以去干其他事情。

    去干其他事情,就是非阻塞。

     

    人自己定期去看开水开没开,这个过程,需要自己去看,是同步。

     

    发现这样效率不高,看一次,水没有开,再看一次,也没开。于是人们想到,能不能这样的思路:水壶的水开了后,水壶自己通知人(调用者)呢?安一个报警器,鸣叫的方式通知人。这种方式是异步。

     

    异步与同步解决的问题:是定期去看调用结果,还是有结果了自动通知去接受。

     

     

     

     

    邮局的信件:我有没有来信,邮政局的人打电话通知我。这是异步。我需要隔一天跑到邮政局看有没有自己的信件。这是同步。

     

    同步调用,异步调用,这样的叫法可能误导了我们。是从调用的角度来说的。

     

    我理解异步,往往是与非阻塞一起使用的,否则异步没多少实际意义,并不能达到提高效率的目的。

     

    比如,我对比现实中,我等待邮局给我通知信件。我不用去邮局跑了,但是这个时间,我们会去干其他事情(可以干其他事情就是非阻塞)。而不是等在这里,别的事情什么都不干,这样提高不了效率(的确避免了人跑去看,人会疲劳,机器没这个概念,所以忽略掉)

     

    因为异步与非阻塞往往混在一起了使用,于是很难去区别两个的区别。实际要解决的问题不同。

     

     

    归纳

     

    通俗地记忆:等待结果的过程中,能不能干别的事情。能,就是非阻塞,不能,就是阻塞。

     

    是调用者自己定期去看调用结果,还是被通知有结果。需要自己去看有没有返回结果,是同步模式。是被通知,则是异步。

     

     

    ------------------------------------------

     

    网 上摘录:对 unix来讲,阻塞式I/O(默认),非阻塞式I/O(nonblock),I/O复用(select/poll/epoll)都属于同步I/O,因为它 们在数据由内核空间复制回进程缓冲区时,都是阻塞的(不能干别的事)。只有异步I/O模型(AIO)是符合异步I/O操作的含义的,即在1数据准备完成、 2由内核空间拷贝回缓冲区后通知进程,在等待通知的这段时间里可以干别的事。

     

    下阶段,研究select,poll,epoll机制

     

  • 相关阅读:
    (转)c++ libcurl一步一步问题解决
    (转载)C++ 用libcurl库进行http通讯网络编程
    (官网)虚幻3--UnrealScript 游戏流程
    (官网)虚幻3--虚幻引擎3命令行参数
    (官网)虚幻3--Scaleform 技术指南
    Android笔记之PenddingIntent使用
    java笔记之字符串截取操作
    java笔记之InputStream转换成String
    java笔记之同一方法的多种传参形式
    Android笔记之调用Resource资源
  • 原文地址:https://www.cnblogs.com/wangtao_20/p/4870112.html
Copyright © 2011-2022 走看看