函数指针
与数据项相似,函数也有地址。函数的地址是存储其机器语言代码的内存的开始地址。它允许在不同的时间传递不同的函数地址。
使用函数指针需要三步:
1. 获取函数的地址: 只要使用函数名(后面不跟参数)即可获得函数地址。
2. 声明一个函数指针
声明指向某种数据类型的指针时,必须指定指针指向的类型。同样,声明指向函数的指针时,也必须指定指向的函数类型。这意味着声明应指定函数的返回类型以及函数的特征标(参数列表)。
这是将pam 替换为了(*pf)。pf就是指针函数。
正确的声明pf 后,便可以将相应的函数地址赋给它。pf = pm;
注意:pam()的特征标和返回值类型必须于 pf 相同,否则编译器将拒绝这种赋值。
3. 使用函数指针来调用函数
pf 扮演的角色与函数名相同,因此使用 (*pf) 时,只需将它看做函数名即可:
double x = pam(4);
double y = (*pf) (5);
实际上C++也允许像使用函数名那样使用pf:
double y = pf(5);
深入探讨函数指针
下面的一些函数原型:
假设声明一个指针,它可指向这三个函数之一:
auto 自动类型推断只能用于单值初始化,不能用于初始化列表。
来看下面的输出语句:
(*p1)(av, 3)和p2(av, 3)都调用指向的函数,并将av, 3作为参数。因此显示的是这两个函数的返回值,返回值类型为const double * (即double值的地址),为查看地址中的实际值,需要使用解引用运算符。
也可建立一个指针数组函数:
如何来调用函数呢?