GO语言学习系列:同步/异步/阻塞/非阻塞

本文详细介绍了同步与异步、阻塞与非阻塞的概念,通过A、B两个线程通信的例子进行阐述。同步异步关注线程间的通信模式,而阻塞非阻塞则涉及线程自身的状态。同步阻塞I/O中,A线程等待B处理结果;同步非阻塞I/O下,A线程定期查询并可执行其他任务;异步阻塞I/O中,A线程不执行其他操作,等待B的返回;异步非阻塞I/O允许A线程在等待B结果的同时继续执行。作者提出异步处理可能类似回调或消息链表,同步处理可能涉及定时器,期待进一步探讨。
摘要由CSDN通过智能技术生成

在消息通信中,经常会把同步/异步/阻塞/非阻塞等概念混淆,在此查找资料,并进行总结。

同步/异步

有A、B两个线程进行通信

同步:A向B发送消息后,B在处理消息的过程中,线程A一直处于主动等待B的消息的状态(不执行其他操作--阻塞,定期发送查询信息--非阻塞),B处理完消息后,A主动得到B的结果,此时A和B之间处于同步模式;

异步:A向B发送消息后,A不主动等待B的消息(继续执行其他操作--非阻塞,不执行--阻塞),B处理消息后,将处理结果返回给A,

此时A和B之间处于异步模式;

注意:同步/异步是指线程之间,与线程等待消息时的状态有关。

阻塞:A向B发送消息后,A处于等待状态不进行其他操作,此时A为阻塞调用;

非阻塞:A向B发送消息后,A在处于等待的同时继续执行其他操作,

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值