函数指针
使用函数指针, 能完成这样的工作:可以编写将另一个函数的地址作为参数的函数, 这样第一个函数就能找到第二个函数, 并且运行它, 与直接调用第一个函数相比, 这种方法很笨拙, 但他允许在不同的时间传递不同函数的地址, 这意味着可以再不同的时间使用不同的函数.
基本需要包含以下步骤:
1.获取函数的地址
2.声明一个函数指针
3.使用函数指针来调用函数
第一步: 获取函数的地址:
获取函数地址很简单, 只需要使用函数名(后面不要跟参数)即可. 例如:think 是一个函数
// 这样就会把函数think的地址传递给函数process
process(think);
// 这样是先调用think函数, 将think的返回值传递给process函数
thought(think());
第二步:声明函数指针
声明指向某种数据类型的指针时, 必须指定指针指向的类型. 同样声明指向函数的指针时, 也必须指定指针指向的函数类型. 这意味着声明指定函数的返回类型以及函数的参数列表, 例如:
// 函数原型, 原型中可以不指定形参变量
double test(int);
// 正确的指针类型声明如下:
// 意思是pfun指向一个需要一个int型参数的返回double类型的函数
double (*pfun)(int);
注意:与test()函数原型类似, 就是将test替换为(*pfun), 由于test是函数, 因此(*pfun)也是函数, 而如果(*pfun)是函数, 则pfun就是指向函数的指针.
通常, 要声明指向特定类型的函数的指针的时候, 可以先写这种函数的原型, 然后用(*pfun)替换函数名, 则pfun就是指向函数的指针.
注意: 必须在声明中使用()将*pfun括起来, 括号的优先级比*高, 因此*pfun(int), 表示pfun是一个返回指针的函数, 而(*pfun)(int)表示fpun是指向函数的指针.
正确声明pfun后, 就可以将相应函数的地址赋给pfun:
pfun = test;
注意test()的参数列表和返回值, 必须和pfun的相同, 否则会报错.
现在来写一个完整函数调用另一个函数的函数声明:
// 声明estimate接收一个指向一个接收int型参数,并且返回double类型的函数的指针
void estimate(int lines, double (*pfun)(int));
// 使用estimate很简单:
// pam是函数名, 就是需要传递进函数estimate的函数的函数名
estimate(50, pam);
<