前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >IO-同步、异步、阻塞、非阻塞

IO-同步、异步、阻塞、非阻塞

作者头像
小梁编程汇
发布2021-12-08 14:19:47
1.2K0
发布2021-12-08 14:19:47
举报
文章被收录于专栏:wallbigwallbig

同步与异步(线程间调用)

代码语言:javascript
复制
同步与异步是对应于调用者与被调用者,它们是线程之间的关系,两个线程之间要么是同步的,要么是异步的

	同步操作时,调用者需要等待被调用者返回结果,才会进行下一步操作

	而异步则相反,调用者不需要等待被调用者返回调用,即可进行下一步操作,被调用者通常依靠事件、回调等机制来通知调用者结果

阻塞与非阻塞(线程内调用)

代码语言:javascript
复制
阻塞与非阻塞是对同一个线程来说的,在某个时刻,线程要么处于阻塞,要么处于非阻塞


阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态:

    阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。

    非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。

同步与异步调用/线程/通信

代码语言:javascript
复制
同步就是两种东西通过一种机制实现步调一致,异步是两种东西不必步调一致


一、同步调用与异步调用:

    在用在调用场景中,无非是对调用结果的不同处理。

    同步调用就是调用一但返回,就能知道结果,而异步是返回时不一定知道结果,还得通过其他机制来获知结果,如:

        a. 状态 b. 通知 c. 回调函数


二、同步线程与异步线程:

    同步线程:即两个线程步调要一致,其中一个线程可能要阻塞等待另外一个线程的运行,要相互协商。快的阻塞一下等到慢的步调一致。

    异步线程:步调不用一致,各自按各自的步调运行,不受另一个线程的影响。


三、同步通信与异步通信:

    同步和异步是指:发送方和接收方是否协调步调一致

    同步通信是指:发送方和接收方通过一定机制,实现收发步调协调。
        如:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式

    异步通信是指:发送方的发送不管接收方的接收状态。
        如:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式。


阻塞可以是实现同步的一种手段!例如两个东西需要同步,一旦出现不同步情况,我就阻塞快的一方,使双方达到同步。

同步是两个对象之间的关系,而阻塞是一个对象的状态。

四种组合方式

代码语言:javascript
复制
同步阻塞方式:
    发送方发送请求之后一直等待响应。
    接收方处理请求时进行的IO操作如果不能马上等到返回结果,就一直等到返回结果后,才响应发送方,期间不能进行其他工作。

同步非阻塞方式:
	发送方发送请求之后,一直等待响应。
	接受方处理请求时进行的IO操作如果不能马上的得到结果,就立即返回,取做其他事情。
	但是由于没有得到请求处理结果,不响应发送方,发送方一直等待。
	当IO操作完成以后,将完成状态和结果通知接收方,接收方再响应发送方,发送方才进入下一次请求过程。(实际不应用)

异步阻塞方式:
	发送方向接收方请求后,不等待响应,可以继续其他工作。
	接收方处理请求时进行IO操作如果不能马上得到结果,就一直等到返回结果后,才响应发送方,期间不能进行其他操作。 (实际不应用)

异步非阻塞方式:
	发送方向接收方请求后,不等待响应,可以继续其他工作。
	接收方处理请求时进行IO操作如果不能马上得到结果,也不等待,而是马上返回去做其他事情。
	当IO操作完成以后,将完成状态和结果通知接收方,接收方再响应发送方。(效率最高)

引用:

https://blog.csdn.net/historyasamirror/article/details/5778378

https://www.cnblogs.com/loveer/p/11479249.html

https://colobu.com/2019/07/26/IO-models/【SOCKET: connect、accpet、读、写】

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021年4月11日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 同步与异步(线程间调用)
  • 阻塞与非阻塞(线程内调用)
  • 同步与异步调用/线程/通信
  • 四种组合方式
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档