27.回调函数实现的原理是什么?

其实之前小风哥写过关于回调函数原理的文章,在这里《10张图让你彻底理解回调函数》,这篇文章内容很全面,但还是有很多同学在微信上问我有没有简化版的,以下就是回调函数原理的极简版。

其实回调函数和普通函数没有本质的区别。

首先让我们来看看普通的函数调用,假设我们在A函数中调用函数func:

  1. void A() {
  2. ...
  3. func();
  4. ...
  5. }

想一想,你怎么知道可以调用func呢?哦,原来func是你自己定义的:

  1. void func() {
  2. blablabla;
  3. }

这很简单吧,现在假设你编写的这段代码无比之牛逼,全世界的程序员都无比疯狂的想引入到自己的项目中,这时你会把A函数编写成一个库供全世界的码农使用。

但此时所有人都发现一个问题,那就是他们都想在A函数中的某个特定点上执行一段自己的代码,作为这个库的创作者你可能会这样实现:

  1. void A() {
  2. ...
  3. // 特定点
  4. if (张三) {
  5. funcA();
  6. } else if (李四) {
  7. funcB();
  8. }
  9. ...
  10. }

假设全世界有一千万码农,那你是不是要有一千万个if else。。。想想这样的代码就很刺激有没有!更好的办法是什么呢?把函数也当做变量!你可以这样定义A函数:

  1. void A(func f) {
  2. ...
  3. f();
  4. ...
  5. }

任何一个码农在调用你的A函数时传入一个函数变量,A函数在合适的时机调用你传入的函数变量,从而节省了一千万行代码

为了让这个过程更加难懂一些,这个函数变量起了一个无比难懂的称呼:回调函数

现在你应该明白了回调函数是怎么一回事了吧,相比回调函数来说我更愿意将其看做函数变量

以上就是回调函数的基本原理,有想看更详细版本的请参考这里。

以上仅仅是回调函数的一种用途,回调函数在基于事件驱动编程以及异步编程时更是必备的,关于事件驱动编程你可以参考这里,GUI编程的同学对此肯定很熟悉。

希望这里的讲解对大家理解回调函数有所帮助。