函数的二进制代码存放在内存四区中的代码段,函数的地址是它在内存中的起始位置。如果把函数的地址作为参数传递给函数,就可以在函数中的灵活的调用其它函数。

使用函数指针的三个步骤:

  • 声明函数指针;
  • 让函数指针指向函数的地址;
  • 通过函数指针调用函数。

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);
}