zoukankan      html  css  js  c++  java
  • 解释什么是异步非阻塞?

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

    同步和异步

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

    阻塞和非阻塞

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

    理解方式

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

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

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

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

    在公交站等公交

      对调用者-乘客而言:

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

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

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

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

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

  • 相关阅读:
    hdu4841 圆桌问题[STL vector]
    hdu1002 A + B Problem II[大数加法]
    hdu1501 Zipper[简单DP]
    C语言学习之结构体
    C++学习之从C到C++
    一键自动格式化你的代码
    C标准库string.h中几个常用函数的使用详解
    Jlink使用技巧系列教程索引
    Jlink使用技巧之合并烧写文件
    Jlink使用技巧之烧写SPI Flash存储芯片
  • 原文地址:https://www.cnblogs.com/Rivend/p/12065474.html
Copyright © 2011-2022 走看看