同步与异步,阻塞与非阻塞

本文深入解析了分布式系统中同步与异步、阻塞与非阻塞的概念区别。同步调用需要等待返回结果,而异步调用则通过状态通知或回调处理结果;阻塞调用会使线程挂起直至结果返回,而非阻塞调用不会阻塞线程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

“阻塞”与”非阻塞”、”同步”与“异步”从分布式系统角度的理解:

同步与异步
同步和异步关注的是消息通信机制 (synchronous communication/ asynchronous communication)。 所谓同步,就是在发出一个调用时,在没有得到结果之前,该调用就不返回。但是一旦调用返回,就得到返回值了。 换句话说,就是由调用者主动等待这个调用的结果。
而异步则是相反,调用在发出之后,这个调用就直接返回了,所以没有返回结果。换句话说,当一个异步过 程调用发出后,调用者不会立刻得到结果。而是在调用发出后,被调用者通过状态、通知来通知调用者,或 通过回调函数处理这个调用。
典型的异步编程模型比如Node.js,举个例子:
普通B/S模式(同步)AJAX技术(异步)
同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事
异步: 请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕

阻塞与非阻塞
阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态.
阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。 非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值