函数指针
函数的二进制代码存放在内存四区中的代码段,函数的地址是它在内存中的起始位置。如果把函数的地址作为参数传递给函数,就可以在函数中的灵活的调用其它函数。
使用函数指针的三个步骤:
- 声明函数指针;
- 让函数指针指向函数的地址;
- 通过函数指针调用函数。
1、声明函数指针
声明普通指针时,必须提供指针的类型。同样,声明函数指针时,也必须提供函数类型,函数的类型是指返回值和参数列表(函数名和形参名不是)。
假设函数的原型是:
int func1(int bh,string str); int func2(int no,string info); int func3(int id,string message); bool func4(int id,string info); bool func5(int id); 则函数指针的声明是: int (*pfa)(int,string); bool (*pfb)(int,string); bool (*pfc)(int);
pfa、pfb、pfc是函数指针名,必须用括号,否则就成了返回指针的函数。
2、函数指针的赋值函数名就是函数的地址。
函数指针的复制:函数指针名=函数名;
3、函数指针的调用
(*函数指针名)(实参);
函数指针名(实参);
示例:
#include <iostream> using namespace std; void zs(int a) { cout << "我叫张三,今年" << a << "岁" << endl; } void ls(int a) { cout << "我叫李四,今年" << a << "岁" << endl; } void show(void (*pf)(int),int a) { cout << "业务开始" << endl; pf(a); cout << "业务结束" << endl; } int main() { show(zs,19); show(ls,20); }