前言
在学习过程中碰到了回调函数这个概念,经上网查询相关资料,现在此进行归纳总结~
什么是回调函数?
通俗说法
你去一个店铺买东西,结果你要的东西现在没有货了,于是你在店员那里留下了你的电话,过了几天店里有货了,店员就打了你的电话,然后你接到电话再去店里取货,在这个例子里,你的电话号码就叫回调函数。
正式定义
百度百科:回调函数_百度百科
当程序运行时,一般情况下,应用程序会时常通过 API 调用库里所预先备好的函数,但是有些库函数却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务,这个被传入的、后又被调用的函数就称为回调函数。
在计算机科学中,回调函数是指一段以参数的形式传递给其它代码的可执行代码,回调过程一般包括以下三个主体:
- 主函数:相当于整个程序的引擎,调度各个函数按序执行
- 回调函数:一个独立的功能函数,如写文件函数
- 中间函数:一个介于主函数和回调函数之间的函数,登记回调函数,通知主函数,起到一个桥梁的作用
中间函数和回调函数是回调的两个必要部分
回调函数的作用
通俗说法
在上述例子中,如果不给店员留电话(回调函数),那就只能一直在店里等,等到有货为止,再取货,这样就会导致时间全部耽搁在这里了,效率较低,而留电话,等有货了再来取,这中间就可以安排别的活动,时间管理大师。
正式说法
在回调中,我们利用某种方式,把回调函数像参数一样传入中间函数,可以这么理解,在传入一个回调函数之前,中间函数是不完整的,换句话说,程序可以在运行时,通过登记不同的回调函数,来决定、改变中间函数的行为,回调机制提供了非常大的灵活性:
# 回调函数
def callback(x):
return x * 2
# 中间函数
def middle_func(x, func):
return 100 + func(x)
# 主函数
def main():
x = 1
res = middle_func(x, callback)
print(res)
main()
# 102
例如 Scrapy 中爬取某个网站的流程和解析方式,整个爬取的循环过程如下所述:
- 以初始的 URL 初始化 Request,并设置回调函数。 当该 Request 成功请求并返回时,将生成 Response,并作为参数传给该回调函数。
- 在回调函数内分析返回的网页内容。返回结果可以有两种形式,一种是解析到的有效结果返回字典或 Item 对象。下一步可经过处理后(或直接)保存,另一种是解析得下一个(如下一页)链接,可以利用此链接构造 Request 并设置新的回调函数,返回 Request。
- 如果返回的是字典或 Item 对象,可通过 Feed Exports 等形式存入到文件,如果设置了 Pipeline 的话,可以经由 Pipeline 处理(如过滤、修正等)并保存。
- 如果返回的是 Reqeust,那么 Request 执行成功得到 Response 之后会再次传递给 Request 中定义的回调函数,可以再次使用选择器来分析新得到的网页内容,并根据分析的数据生成 Item。
同步回调:也称阻塞式回调,一种阻塞式调用方式,调用方要等待对方执行完毕才返回,它是一种单向调用,回调函数的调用一定发生在起始函数返回之前:
异步回调:也称延迟式回调,回调函数的调用有可能是在起始函数返回之后,客户端不等待调用执行完成返回结果,不过依然可以通过回调函数接收到返回结果的通知,如果客户端并不关心结果,则可以变成一个单向的调用,在调用一个方法时,如果执行时间比较长,我们可以传入一个回调的方法,当方法执行完时,让被调用者执行给定的回调方法:
总结
以上为对回调函数的总结归纳,如有错误或者看法,欢迎评论区留言交流指正~
参考资料:
https://blog.csdn.net/yilovexing