网站做全景图,沈阳智能模板建站,做网页设计的工资有多高,引进韩国电影一、回调函数
回调函数就是通过函数指针调用的函数
如果你把函数的指针作为参数传递给另外一个函数#xff0c;当这个指针被用来调用其所指向的函数时#xff0c;被调用的函数就是回调函数。回调函数并不是一个单一的函数实现的#xff0c;而是在某种情况下#xff0c;编…一、回调函数
回调函数就是通过函数指针调用的函数
如果你把函数的指针作为参数传递给另外一个函数当这个指针被用来调用其所指向的函数时被调用的函数就是回调函数。回调函数并不是一个单一的函数实现的而是在某种情况下编写者根据需要所编写的在特定的时间或条件发生由另外一方的调用的用于对该事件的相应
这是我们普通实现计算器的思路和代码
#includestdio.h
int Add(int x, int y)
{return x y;
}
int Sub(int x, int y)
{return x - y;
}
int Mul(int x, int y)
{return x * y;
}
int Div(int x, int y)
{return x / y;
}
void menu()
{printf(*************************\n);printf(**1:add***********2:sub**\n);printf(**3:mul***********4:div**\n);printf(*********0:exit**********\n);printf(*************************\n);}
int main()
{int x 0;int y 0;int input 0;int ret 0;do{menu();printf(请输入);scanf(%d, input);switch (input){case 0:break;case 1:printf(请输入两个数);scanf(%d %d, x, y);ret Add(x, y);printf(%d%d%d\n, x, y, ret);break;case 2:printf(请输入两个数);scanf(%d %d, x, y);ret Sub(x, y);printf(%d-%d%d\n, x, y, ret);break;case 3:printf(请输入两个数);scanf(%d %d, x, y);ret Mul(x, y);printf(%d*%d%d\n, x, y, ret);break;case 4:printf(请输入两个数);scanf(%d %d, x, y);ret Div(x, y);printf(%d/%d%d\n, x, y, ret);break;default:printf(输入错误请重新输入\n);break;}} while (input);return 0;
}
然后我们发现这种代码和思路非常非常的冗余对于初学者来说很友好但是对于进阶来说
这种重复性的代码不是很好的选择那么有没有方法让他简化一下哪
当然有用回调函数这里Cacl()函数就是回调函数。
int Add(int* x, int* y)//1
{return *x *y;
}
int Sub(int* x, int* y)//1
{return *x *y;
}
int Mul(int* x, int* y)//1
{return *x *y;
}
int Div(int* x, int* y)//1
{return *x *y;
}void meau()
{printf(*************************\n);printf(**1:add***********2:sub**\n);printf(**3:mul***********4:div**\n);printf(*********0:exit**********\n);printf(*************************\n);}
void Cacl(int(*pf)(int*, int*))
{int ret 0;int x 0, y 0;printf(请输入两个数);scanf(%d %d, x, y);ret pf(x,y);printf(%d\n, ret);}int main()
{int a 0, b 0;int input 0;do{meau();printf(请输入);scanf(%d, input);switch (input){case 0:break;case 1:Cacl(Add);break;case 2:Cacl(Sub);break;case 3:Cacl(Mul);break;case 4:Cacl(Div);break;default:printf(输入错误请重新输入);break;}} while (input);return 0;
}二、qsort函数
qsort函数
qsort函数时C语言提供的一个库函数头文件时stdlib.h对任意类型的元素都能进行排序。 void qsortvoid*base, size-t nums, size_t size, int(*compare)(const*void elem1,const*void elem2) ; void*base 是待排序数组的第一个首元素的地址。 size_t nums是待排序数组的元素个数。 size_t size是待排序数组中每个元素的大小。 int(*compare)(const*void elem1,const*void elem2)函数指针-------传函数的地址。 注意int(*compare)(const*void elem1,const*void elem2))-----比较函数需要使用qsort函数的程序员自己实现并且有以下要求。 当p1p2时返回小于1的数 。 当p1p2时返回等于0的数 。 当p1p2时返回大于1的数。 1.通过结构体中的整形成员排序
#includestdio.h
#includestdlib.h
void Print(int arr[], int sz)
{int i 0;for (i 0; i sz; i){printf(%d , arr[i]);}
}
struct stu
{char name[20];int age;
};
//按照年龄比较排序结构体数组
int cmp_stu_by_age(const void* e1, const void* e2)
{//return (*((struct stu*)e1)).age (*((struct stu*)e2)).age;return ((struct stu*)e1)-age - ((struct stu*)e2)-age;
}
void test2()
{struct stu arr[] { {zhangsan,20},{lisi,35},{wangwu,18} };int sz sizeof(arr) / sizeof(arr[0]);qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_age);//通过age排序
}
int main()
{test2();return 0;
}
2.通过结构体中的字符串成员排序
#includestdio.h
#includestdlib.h
#includestring.h
void Print(int arr[], int sz)
{int i 0;for (i 0; i sz; i){printf(%d , arr[i]);}
}
struct stu
{char name[20];int age;
};
//按照名字比较排序结构体数组
int cmp_stu_by_name(const void* e1, const void* e2)
{//注意强转是暂时的需要带上()return strcmp(((struct stu*)e1)-name, ((struct stu*)e2)-name);//这里借助strcmp函数比较字符串返回值恰好与函数的返回值要求相同
}
void test2()
{struct stu arr[] { {zhangsan,20},{lisi,35},{wangwu,18} };int sz sizeof(arr) / sizeof(arr[0]);qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_name);
}
int main()
{test2();return 0;
}到这里指针系列就结束了感谢各位支持但是我们都知道学习永无止境
我们都会走向属于自己的顶峰