一:函数指针
回调机制在C语言中是通过函数指针来实现的,通过将回调函数的地址传给被调函数从而实现回调(注意分清回调函数和被调函数的概念,以便在下文论述中理解)。因此要实现回调,必须首先定义函数指针。
例如:
void Func(char *s) // 函数原型
void (*pFunc)(char *); //函数指针
可以看出,函数的定义和函数指针的定义非常类似。一般情况下,为了简化函数指针类型的变量定义,提高程序的可读性,我们需要把函数指针类型自定义一下。
typedef void(*pcb)(char *);
typedef的功能是定义新的类型。第一句就是定义了一种pcb的类型,并定义这种类型为指向某种函数的指针,这种函数以一个char*为参数并返回void类型。后面就可以像使用int,char一样使用pcb了。
例如
pcb pFun;
void wh(char * c){return c};
pFun = wh;
这段代码便使用这个新类型定义了变量pFun,然后就可以把对应的函数名wh,其实也就是函数地址&wh赋给它了。
回调函数也可以像普通函数一样被程序调用,但是只有当它被当作参数传递给被调函数时才能称作回调函数。
例:被调函数:
void GetcallBack(pcb callback)
{
/*do something*/
}
用户在调用上面的函数时,需要自己实现一个pcb类型的回调函数:
void fCallback(cha *s)
{
/*do something*/
}
然后就可以直接把fCallback当作一个参数传递给GetcallBack.
GetcallBack(fCallbcak);
二:什么是回调函数
总结上述示列,回调函数就是一个通过函数指针调用的函数。如果你把函数指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数。
转载:https://wenku.baidu.com/vie/f0327dd026fff705cc170a14.html