DUBBO研究与学习二:打基础-同步调用、回调和异步调用区别

调用方式

软件模块之间总是存在着一定的接口,从调用方式上,可以把他们分为三类:同步调用、回调和异步调用。

现在就来学习一下他们是什么以及有什么区别。

同步调用

同步调用是一种阻塞式调用,调用方要等待对方执行完毕才返回,它是一种单向调用。

举个栗子:

4x100米接力赛。

现在1道有甲、乙、丙、丁四个选手。甲听到枪响后,率先跑了出去。乙、丙、丁都需要等着,直到甲把接力棒交到乙手里,乙才开始跑,依次是丙、丁。

这种就是典型的阻塞机制,无论如何我们只能等待上一个任务的完成,上一个任务没完成就只能等着。这样造成的问题是,我们一直在浪费系统资源。

回调

回调是一种双向调用模式,也就是说,被调用方在接口被调用时也会调用对方的接口。     

栗子

管理的上传下达机制。以CEO、项目经理、开发人员为例。CEO给了一个需求,发邮件给项目经理。项目经理收到后发送阅读收条,CEO便确定这件事传达了下去;接着项目经理再向下传达。

这里调用方就是CEO,被调用方是项目经理。CEO给项目经理发邮件,就是调用被调用方的接口。项目经理收到后发送阅读收条通知CEO自己已经收到了邮件,就是调用CEO的接口。


more

回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。


图片来源(维基百科)

当程序跑起来时,一般情况下,应用程序(application program)会时常通过API调用库里所预先备好的函数。但是有些库函数(library function)却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务。这个被传入的、后又被调用的函数就称为回调函数(callback function)


Demo(Python写成的回调函数的简单示例)

链接:https://www.zhihu.com/question/19801131/answer/27459821
来源:知乎


请注意:上图中的库函数在这里改称为了中间函数。

‘even.py’

#回调函数1
#生成一个2k形式的偶数
def double(x):
    return x * 2
    
#回调函数2
#生成一个4k形式的偶数
def quadruple(x):
    return x * 4
'callback_demo.py'

from even import *

#中间函数
#接受一个生成偶数的函数作为参数
#返回一个奇数
def getOddNumber(k, getEvenNumber):
    return 1 + getEvenNumber(k)
    
#起始函数,这里是程序的主函数
def main():    
    k = 1
    #当需要生成一个2k+1形式的奇数时
    i = getOddNumber(k, double)
    print(i)
    #当需要一个4k+1形式的奇数时
    i = getOddNumber(k, quadruple)
    print(i)
    #当需要一个8k+1形式的奇数时
    i = getOddNumber(k, lambda x: x * 8)
    print(i)
    
if __name__ == "__main__":
    main()

异步调用

异步调用是一种类似消息或事件的机制,不过它的调用方向刚好相反,接口的服务在收到某种讯息或发生某种事件时,会主动通知客户方(即调用客户方的接口)。

栗子:

项目经理下手里有四个开发任务,估计一天的量,分别分给了下面的四个开发人员A、B、C和D。A是骨灰级程序员,几下就完成了告诉了项目经理,B和C在一天完成告诉了项目经理,D是个小菜,两天才完成告诉了项目经理,这时候项目经理知道整个开发任务完成了。


拓展

        在这里简单介绍了一下同步调用、回调和异步调用的区别。有兴趣的同学还可以关于同步回调、异步回调及更多查询一下相关资料进行了解学习。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值