美文网首页
IO中的阻塞、非阻塞、同步、异步

IO中的阻塞、非阻塞、同步、异步

作者: ppyy_power | 来源:发表于2018-12-04 13:44 被阅读0次

    转载自https://mp.weixin.qq.com/s/dLciyzVfJno1nYyugWoryw

    同步、异步、阻塞、非阻塞都是和IO(输入输出)有关的概念。最简单的文件读取就是IO操作。而在文件读取这件事儿上,可以有多种方式。

    1.什么是同步和异步
    说到烧水,我们都是通过热水壶来烧水的。在很久之前,科技还没有这么发达的时候,如果我们要烧水,需要把水壶放到火炉上,我们通过观察水壶内的水的沸腾程度来判断水有没有烧开。

    随着科技的发展,现在市面上的水壶都有了提醒功能,当我们把水壶插电之后,水壶水烧开之后会通过声音提醒我们水开了。

    对于烧水这件事儿来说,传统水壶的烧水就是同步的,高科技水壶的烧水就是异步的。

    同步请求,A调用B,B的处理是同步的,在处理完之前他不会通知A,只有处理完之后才会明确的通知A。

    异步请求,A调用B,B的处理是异步的,B在接到请求后先告诉A我已经接到请求了,然后异步去处理,处理完之后通过回调等方式再通知A。

    所以说,同步和异步最大的区别就是被调用方的执行方式和返回时机。同步指的是被调用方做完事情之后再返回,异步指的是被调用方先返回,然后再做事情,做完之后再想办法通知调用方。
    2.什么是阻塞和非阻塞

    还是那个烧水的例子,当你把水放到水壶里面,按下开关后,你可以坐在水壶前面,别的事情什么都不做,一直等着水烧好。你还可以先去客厅看电视,等着水开就好了。

    对于你来说,坐在水壶前面等就是阻塞的,去客厅看电视等着水开就是非阻塞的。

    阻塞请求,A调用B,A一直等着B的返回,别的事情什么也不干。

    非阻塞请求,A调用B,A不用一直等着B的返回,先去忙别的事情了。

    所以说,阻塞非阻塞最大的区别就是在被调用方返回结果之前的这段时间内,调用方是否一直等待。阻塞指的是调用方一直等待别的事情什么都不做。非阻塞指的是调用方先去忙别的事情。

    Java中的三种IO模型

    BIO (Blocking I/O):同步阻塞I/O模式,数据的读取写入必须阻塞在一个线程内等待其完成。
    NIO (New I/O):同时支持阻塞与非阻塞模式,但主要是使用同步非阻塞IO。
    AIO (Asynchronous I/O):异步非阻塞I/O模型。

    相关文章

      网友评论

          本文标题:IO中的阻塞、非阻塞、同步、异步

          本文链接:https://www.haomeiwen.com/subject/lsumcqtx.html