zoukankan      html  css  js  c++  java
  • 同步、异步,阻塞、非阻塞

    同步:所谓同步,就是指发出一个功能调用时,在没有得到结果之前,该调用就不返回;也就是说必须一件一件的,等前一件事做完再做下一件事。

    异步:异步就是和同步的概念是相对应的。当一个异步过程调用发生后,调用者不能立刻得到结果,该调用就返回。实际处理这个调用的部件在完成后,通过状态、通知和回调函
    数来通知调用者。

    阻塞:阻塞调用是指调用过程返回之前,当前线程会被挂起(线程进入非可执行状态,在这个状态下,cpu不会给线程分配时间片,即线程暂停执行)。函数只有在得到结果之后
    才会返回。
    非阻塞:非阻塞为是相对与阻塞的,指在不能立刻得到返回结果之前,该函数不会阻塞当前的线程,而会立即返回。

    (1)同步,就是我调用一个功能,该功能没有结束之前,我死等结果。

    (2)异步,就是我调用一个功能,不需要知道该功能的结果,该功能有结果后通知我。

    (3)阻塞,就是调用我,我没有接收完数据或者没有得到结果之前,我不会返回。

    (4)非阻塞,就是调用我,我立即返回,通过select通知调用者。

    同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞

    阻塞IO和非阻塞IO的区别就在于:应用程序的调用是否立即返回

    阻塞和非阻塞是指当进程访问的数据如果尚未就绪,进程是否需要等待,简单说这相当于函数内部的实现区别,也就是未就绪时是直接返回还是等待就绪 ; 而同步和异步是指访问数据

    的机制,同步一般指主动请求并等待I/O操作完毕的方式,当数据就绪后在读写的时候必须阻塞(区别就绪与读写二个阶段,同步的读写必须阻塞),异步则指主动请求数据后便可以继续处

    理其它任务,随后等待I/O,操作完毕的通知,这可以使进程在数据读写时也不阻塞(等待"通知")。

     

    注意:在这里可能会把同步和阻塞等同起来,实际上两者是不同的。对于同步调用,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已。而阻塞线程进入非可执

    行状态,在这个状态下,cpu不会给线程分配时间片,即线程暂停执行。

    同步和异步仅仅是关于所关注的消息如何通知的机制。同步的情况下,是由处理消息者自己去等待消息是否被触发,而异步的情况下是由触发机制来通知处理消息者。阻塞和非阻塞

    该是发生在消息的处理的时刻。阻塞其实就是等待,发出通知,等待结果完成。非阻塞属于发出通知,立即返回结果,没有等待过程。

  • 相关阅读:
    This theme is released under creative commons licence, all links in the footer should remain intact解决方法 Fred
    增加ubuntu的内存——设置Swap增加内存
    OpenFlow硬件交换机制作及刷机教程
    ubuntu设置中文
    配置树莓派/Linux默认声卡设备
    github基础操作
    Linux手动添加系统环境共享库路径
    Ubuntu登录界面添加root用户登录选项
    python实现树莓派开机自动发送IP到指定邮箱
    语音信号实时采集与处理
  • 原文地址:https://www.cnblogs.com/ancient/p/3629259.html
Copyright © 2011-2022 走看看