学做网站论坛vip账户,资源搜索,网站建设云创,推广网页1.回调函数是什么#xff1f;
回调函数就是一个通过函数指针调用的函数。 如果你把函数的指针#xff08;地址#xff09;作为参数传递给另⼀个函数#xff0c;当这个指针被⽤来调⽤其所指向的函数时#xff0c;被调⽤的函数就是回调函数。回调函数不是由该函数的实现⽅…1.回调函数是什么
回调函数就是一个通过函数指针调用的函数。 如果你把函数的指针地址作为参数传递给另⼀个函数当这个指针被⽤来调⽤其所指向的函数时被调⽤的函数就是回调函数。回调函数不是由该函数的实现⽅直接调⽤⽽是在特定的事件或条件发⽣时由另外的⼀⽅调⽤的⽤于对该事件或条件进⾏响应。
第13讲中我们写的计算机的实现的代码中红⾊框中的代码是重复出现的其中虽然执⾏计算的逻辑是区别的但是输⼊输出操作是冗余的有没有办法简化⼀些呢
因为红⾊框中的代码只有调⽤函数的逻辑是有差异的我们可以把调⽤的函数的地址以参数的形式传递过去使⽤函数指针接收函数指针指向什么函数就调⽤什么函数这⾥其实使⽤的就是回调函数的功能。
1使用回调函数改造前
//使⽤回调函数改造前
#include stdio.h
int add(int a, int b)
{return a b;
}
int sub(int a, int b)
{return a - b;
}
int mul(int a, int b)
{return a * b;}
int div(int a, int b)
{return a / b;
}
int main()
{int x, y;int input 1;int ret 0;do{printf(******************printf( 1:add printf( 3:mul printf(******************printf(请选择);scanf(%d, input);switch (input){case 1:printf(输⼊操作数);scanf(%d %d, x, y)ret add(x, y);printf(ret %d\n, rbreak;case 2:printf(输⼊操作数);scanf(%d %d, x, y)ret sub(x, y);printf(ret %d\n, rbreak;case 3:printf(输⼊操作数);scanf(%d %d, x, y)ret mul(x, y);printf(ret %d\n, rbreak;case 4:printf(输⼊操作数);scanf(%d %d, x, y)ret div(x, y);printf(ret %d\n, rbreak;case 0:printf(退出程序\n);break;default:printf(选择错误\n);break;}} while (input);return 0;
}2使用回到函数改造后
//使⽤回到函数改造后
#include stdio.h
int add(int a, int b)
{return a b;
}
int sub(int a, int b)
{return a - b;
}
int mul(int a, int b)
{return a * b;}
int div(int a, int b)
{return a / b;
}
void calc(int(*pf)(int, int))
{int ret 0;int x, y;printf(输⼊操作数);scanf(%d %d, x, y);ret pf(x, y);printf(ret %d\n, ret);
}
int main()
{int input 1;do{printf(******************printf( 1:add printf( 3:mul printf(******************printf(请选择);scanf(%d, input);switch (input){case 1:calc(add);break;case 2:calc(sub);break;case 3:calc(mul);break;case 4:calc(div);break;case 0:printf(退出程序\n);break;default:printf(选择错误\n);break;}} while (input);return 0;
}2.qsort使用举例
#include stdio.h
//qosrt函数的使⽤者得实现⼀个⽐较函数
int int_cmp(const void * p1, const void * p2)
{return (*( int *)p1 - *(int *) p2);
}
int main()
{int arr[] { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };int i 0;qsort(arr, sizeof(arr) / sizeof(arr[0]), sizeof (int), int_cmp);for (i 0; i sizeof(arr) / sizeof(arr[0]); i){printf( %d , arr[i]);}printf(\n);return 0;
}3. qsort函数的模拟实现 由于在前面的博客里qsort函数的模拟实现已经讲的非常详细了所以这里我就简单写一下源码不懂得可以去看我前面的博客学习怎样模拟实现qsort函数感谢理解支持 使用回调函数模拟实现qsort采用冒泡的方式。 注意这里第一次使用 void* 的指针讲解 void* 的作用。
#include stdio.h
int int_cmp(const void * p1, const void * p2)
{return (*( int *)p1 - *(int *) p2);
}
void _swap(void *p1, void * p2, int size)
{int i 0;for (i 0; i size; i){char tmp *((char *)p1 i);*(( char *)p1 i) *((char *) p2 i);*(( char *)p2 i) tmp;}
}
void bubble(void *base, int count , int size, int(*cmp )(void *, void *))
{int i 0;int j 0;for (i 0; i count - 1; i){for (j 0; jcount-i-1; j){if (cmp ((char *) base j*size , (char *)base (j 1)*size) 0){_swap(( char *)base j*size, (char *)base (j 1)*size, size);}}}
}
int main()
{int arr[] { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };//char *arr[] {aaaa,dddd,cccc,bbbb};int i 0;bubble(arr, sizeof(arr) / sizeof(arr[0]), sizeof (int), int_cmp);for (i 0; i sizeof(arr) / sizeof(arr[0]); i){printf( %d , arr[i]);}printf(\n);return 0;
}4.sizeof和strlen的对比
4.1sizeof
在学习操作符的时候我们学习了 sizeof sizeof 计算变量所占内存内存空间大小的单位是字节如果操作数是类型的话计算的是使⽤类型创建的变量所占内存空间的大小。 sizeof 只关注占⽤内存空间的大小不在乎内存中存放什么数据。 比如
#inculde stdio.h
int main()
{int a 10;printf(%d\n, sizeof(a));printf(%d\n, sizeof a);printf(%d\n, sizeof(int));return 0;
}4.2strlen
strlen 是C语言库函数功能是求字符串长度。函数原型如下
size_t strlen ( const char * str );统计的是从 strlen 函数的参数 str 中这个地址开始向后 \0 之前字符串中字符的个数。 strlen 函数会⼀直向后找 \0 字符直到找到为止所以可能存在越界查找。
#include stdio.h
int main()
{char arr1[3] {a, b, c};char arr2[] abc;printf(%d\n, strlen(arr1));printf(%d\n, strlen(arr2));printf(%d\n, sizeof(arr1));printf(%d\n, sizeof(arr1));return 0;
}4.3sizeof 和 strlen的对比
sizeof sizeof是操作符sizeof计算操作数所占内存的大小单位是字节不关注内存中存放什么数据 strlen strlen是库函数使⽤需要包含头文件 string.hsrtlen是求字符串长度的统计的是 \0 之前字符的隔个数关注内存中是否有 \0 如果没有 \0 就会持续往后找可能会越界