回调函数讲解

回调函数:或简称回调(Callback 即 call then back 被主函数调用运算后会返回主函数),是指通过函数参数传递到其他代码的,某一块可执行代码的引用。这一设计允许了底层代码调用在高层定义的子程序。(回调函数是一个通过函数指针调用的函数,把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,这即为回调函数。)

把一段可执行的代码像参数一样传递给其他代码,而这段代码会在某个时刻被调用执行,这称为回调。如果代码立即被执行就称为同步回调;如果在之后晚点的某个时间再执行,则称为异步回调。

回调函数的实现:将一个函数指针以参数的形式传递给另一个函数。回调函数将包含以下三个部分:定义回调函数、注册回调函数、执行回调函数。

1、定义回调函数

回调函数的定义与普通函数的定义没有区别,例如:

/*高层*/

void CallBack(void)

{

        //TODO

}

注册回调函数并执行:

void RegisterCallBack(void(*Callback)(void))

{

        Callback();

}

该注册函数的形参是一个函数指针,因此可以将定义的函数的指针作为参数传到当前这个函数,从而可以实现底层调用高层的代码。调用方式可以是:

RegisterCallBack(CallBack);       RegisterCallBack(&CallBack);

定义函数指针:typedef void (*CallBack)(void);

static CallBack MyCallBack = NULL;

注册函数:

void RegisterCallBack(void(*CallBack)(void))

{

        MyCallBack = CallBack;

}

带参数的回调函数:

void CallBack(int x)

{

        printf("Hello, This is a CallBack Funcation: %d! \n",x);

}

void Handle(int x, void (*CallBack)(void))

{

        CallBack(x);

}

itn main()

{

        int x = 15;

        Hendle(x, CallBack);

        return 0;

}

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回调函数是一种常见的编程技巧,它允许我们在程序执行过程中动态地指定一个函数,并将其作为参数传递给另一个函数,在满足特定条件时调用该函数。这种技巧在C语言中尤为常见,下面是一个回调函数的使用例子及讲解。 假设我们有一个函数sort_array,用于对一个整型数组进行排序,其函数原型如下: ```c void sort_array(int* arr, int size); ``` 现在,我们想对一个字符串数组进行排序,该数组的每个元素都是一个字符串。但是,我们如何定义比较函数呢?因为字符串之间的比较是有多种方式的,例如按照字典序、按照长度等等。 为了解决这个问题,我们可以使用回调函数。我们定义一个函数指针类型,用于表示比较函数的类型: ```c typedef int (*compare_func)(const void*, const void*); ``` 该类型的定义表示,一个比较函数应该接受两个const void*类型的参数,并返回一个int类型的值,表示两个参数的大小关系。 然后,我们可以修改sort_array函数的原型,将比较函数作为第三个参数传入: ```c void sort_array(void* arr, int size, compare_func cmp); ``` 在sort_array函数内部,我们调用cmp函数来比较数组中的元素: ```c void sort_array(void* arr, int size, compare_func cmp) { // ... for (int i = 0; i < size - 1; ++i) { for (int j = i + 1; j < size; ++j) { if (cmp(arr + i, arr + j) > 0) { // 交换 arr[i] 和 arr[j] } } } // ... } ``` 这里的arr + i和arr + j表示数组中第i个元素和第j个元素的地址。cmp(arr + i, arr + j)表示调用比较函数来比较这两个元素的大小关系。 现在,我们可以定义一个比较函数,例如按照字符串长度从小到大排序: ```c int cmp_by_length(const void* a, const void* b) { const char* s1 = *(const char**)a; const char* s2 = *(const char**)b; return strlen(s1) - strlen(s2); } ``` 这个函数接受两个const void*类型的参数,我们需要将它们转换为const char**类型的指针,然后比较它们的长度。 最后,我们可以调用sort_array函数来对字符串数组进行排序: ```c const char* arr[] = { "hello", "world", "c", "language", "programming" }; int size = sizeof(arr) / sizeof(arr[0]); sort_array(arr, size, cmp_by_length); ``` 这里的arr是一个字符串数组,我们可以通过sizeof(arr) / sizeof(arr[0])来计算它的长度。最后一个参数是我们定义的比较函数,表示按照字符串长度从小到大排序。 这就是回调函数的一个使用例子及讲解,它允许我们在程序执行过程中动态地指定一个函数,并将其作为参数传递给另一个函数,从而实现更加灵活的编程。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值