前言
这篇博客,我们来了解一下什么叫回调函数。
函数指针
函数指针,从字面意思上理解,它是一个指针,只不过它指向一个函数。
函数指针可以这样定义
int (*p_func)(int, int);
这就定义了一个函数指针,它指向一个函数,这个函数有两个参数,都是int类型,这个函数返回值是一个int类型的值。
大家还可能将这两个混淆:
int (*p_func)(int, int);
int *p_func(int, int);
第一行就是声明了一个指向函数的指针,这个函数有两个int型的参数,返回值是int。
第二行就是声明了一个函数,这个函数有两个int型的参数,返回值是int。
说白了就是第一行声明了一个指针,第二行声明了一个函数。
我们这样区分它们,(*p_func)加了括号,先读括号里面的,括号里面就是一个指针,说明它就是一个指针。
函数指针的的作用就是把函数当成一个参数传递下去,下面是一个简单的例子
#include <stdio.h>
int callback_add(int a, int b)
{
return a + b;
}
int fun(int (*callback)(int, int), int a, int b)
{
return callback(a, b);
}
int main()
{
int a = 10;
int b = 20;
int sum = fun(callback_add, a, b);
printf("sum = %d\n", sum);
return 0;
}
这是一个简单的例子,我们定义了一个需要被回调的函数callback_add,这个返回两个数的和。然后定义fun去调用这个回调函数。
signal函数解释
我们在linux中,经常会用signal实现对信号的捕获,signal也用到了回调函数的知识。
我们看一下signal函数的定义,
void (*signal(int signum, void (*handler)(int)))(int);
下面是摘自这篇博客的解释,感觉这里已经讲得很好了。
链接[https://blog.csdn.net/u010416101/article/details/44218767?utm_source=blogxgwz5]
//一般我们这样表示signal函数,便于理解
typedef void (*sig_t)(int);
sig_t signal(int signum, sig_t handler);
//中间部分
//signal函数有2个参数,第一个是int,第二个是无返回值,带一个int参数的函数指针
signal( int sig, void (*func)(int));
//外围
//signal函数返回的是一个函数指针,无返回值,有一个int参数
void (*signal(xxx)) (int);
//简化
//Sigfunc就代表的就是一个 返回值是一个无返回值,有一个int参数的函数。
typedef void Sigfunc(int)
//最后就成了这样
Sigfunc *signal(int, Sigfunc*)
回调函数的应用
- 解耦
参考链接:https://blog.csdn.net/qican_7/article/details/100669020
有一位朋友用分层的概念来解释了回调机制:callback函数为B层,main函数和print函数为A层,A层调用了B层的回调函数callmeback,而B层的回调函数调用了A层的实现函数print。说白了B层就是一个接口。
- 异步
最典型的例子就是上卖弄介绍的signal函数,实现对信号的捕获,是实现异步的一种方法。
反思
不足之处欢迎指出