什么回调?维基百科是这样解释的:回调是一段可执行的代码通过参数传递给别一段代码,以期望在一个合适的时间调用这个参数(可执行的代码)。
回调函数说白了就是定义一个函数,然后通过参数传递给另一个函数调用。回调不仅是一种技术,更是一种编程思想,上面是通过回调函数来实现的,但它不仅限于回调函数,也可以用其它的技术实现(如面向对象的实现)。
案例:
typedef int (*Compare)(const Person&, const Person&);
//交换两个元素
void swap(Person* p1, Person *p2)
{
Person p = *p1;
*p1 = *p2;
*p2 = p;
}
//排序(本例中采用冒泡排序)
void PersonSort(Person* persons, int count, Compare pCompare)
{
for (int i = 0; i < count-1; i ++)
{
for (int j = 0; j < count - i -1; j++)
{
if (pCompare(persons[j], persons[j+1]) > 0)
{
swap(persons+j, persons+j+1);
}
}
}
}
//按照年龄进行排序
int CompareByAge(const Person& p1, const Person& p2)
{
return p1.age - p2.age;
}
void TestCallBack()
{
//创建Person的一组对象persons,对象中的各个值为0到100的随机数
srand((unsigned)time(NULL));
Person persons[10];
for(int i = 0; i < 10; i ++)
{
persons[i].age = rand()%100;
persons[i].weight = rand()%100;
persons[i].height = rand()%100;
}
//【todo】
//根据年龄进行排序。
PersonSort(persons, 10, CompareByAge);
for(int i = 0; i < 10; i ++)
{
std::cout << persons[i].age << "\t" << persons[i].weight << "\t" << persons[i].height << std::endl;
}
}
//按照体重进行排序
int CompareByHeightWeight(const Person& p1, const Person& p2)
{
return (p1.height + p1.weight) - (p2.height + p2.weight);
}
void TestCallBack()
{
//创建Person的一组对象persons,对象中的各个值为0到100的随机数
srand((unsigned)time(NULL));
Person persons[10];
for(int i = 0; i < 10; i ++)
{
persons[i].age = rand()%100;
persons[i].weight = rand()%100;
persons[i].height = rand()%100;
}
//【todo】
//根据年龄进行排序。
PersonSort(persons, 10, CompareByHeightWeight);
for(int i = 0; i < 10; i ++)
{
std::cout << persons[i].age << "\t" << persons[i].weight << "\t" << persons[i].height << "\t" << persons[i].weight + persons[i].height << std::endl;
}
}