回调
来源:互联网 发布:宏观经济指标数据 编辑:程序博客网 时间:2024/06/03 16:02
什么是回调
转自 http://blog.csdn.net/luoweifu/article/details/40871849
上一篇文章中讲了“函数的指针”,那么函数指针有什么用呢?一个最常用的地方就是回调。
什么回调?维基百科是这样解释的:回调是一段可执行的代码通过参数传递给别一段代码,以期望在一个合适的时间调用这个参数(可执行的代码)。
参考:In computer programming, a callback is a piece of executable code that is passed as an argument to other code, which is expected to call back(execute) the argument at some convenient time.
如果你已明白回调或理解上面这一句话,可以漂过,感觉头昏的请往下看。
从一个需求开始
先不扯淡,直接拿事实说话。假设有这么一个需求:
有一Person类定义如下:
struct Person
{
int age;
float weight;
float height;
};
现要对Person的一组对象进行排序,但并没有确定根据什么规则来排序,有时需要根据年龄进行排序,有时需要根据身高进行排序,有时可能是根据身高和体重的综合情况来排序,还有可能……
你可能会想到这样写,定义三个函数分别根据年龄、体重、身高进行排序:
void SortByAge(Person* persons, int count);
void SortByWeight(Person* persons, int count);
void SortByHeight(Person* persons, int count);
如果要根据身高和体重的综合情况来排序,那你还得再定义一个函数。这样是不是代码冗余且很繁琐?但如果你会用回调,这个问题就会很简单。
用回调实现对Person的排序:
如果你要根据年龄来进行排序,只要实现一个Compare类型的函数,再调用上面的PersonSort函数就可以实现根据年龄排序的功能。如:
说明:以上调用TestCallBack函数时需要包含头文件<iostream>、<time.h>
这样如果需求发生变更(如要根据每个Person身高和体重的总和来排序),只需求再定义一个Compare类型的函数,而不用再对PersonSort函数做任何改动。如下:
C++ STL中的Sort(在<algorithm>头文件中)用的就是这种技术:
template<class RandomAccessIterator> void sort( RandomAccessIterator first, RandomAccessIterator last ); template<class RandomAccessIterator, class Predicate> void sort( RandomAccessIterator first, RandomAccessIterator last, Predicate comp );
通过上面一个实例的分析,应该对回调有所了解和认识了吧!回调函数说白了就是定义一个函数,然后通过参数传递给另一个函数调用。回调不仅是一种技术,更是一种编程思想,上面是通过回调函数来实现的,但它不仅限于回调函数,也可以用其它的技术实现(如面向对象的实现)。如果想更深入的了解,请看后续的文章。
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调
- 回调?
- 回调
- Python学习笔记(一)——Anaconda安装与配置(windows)
- 如何从业余爱好者自学进阶成专业开发者
- 转:问题解决:The project cannot be built until build path errors are resolved
- FineReport中如何制作树数据集来实现组织树报表
- XML约束
- 回调
- jquery源码学习
- 模拟(HDU 5319,Painter)
- 100. Same Tree
- 2017.5
- Eclipse快捷键
- _winapi Createprocess FileNotFoundError: [WinError 2] 系统找不到指定的文件
- 验证RT9742是否做的防倒灌处理 磁珠 电感 三位数码管
- 初学者如何选择合适的机器学习算法