C++|C++ 函数指针和函数类型

函数指针和函数类型

  • 函数指针指向的是函数而非对象。和其他指针类型一样,函数指针指向某种特定类型。
  • 函数类型由它的返回值和参数类型决定,与函数名无关。
bool length_compare(const string &, const string &);

【C++|C++ 函数指针和函数类型】上述函数类型是:bool (const string &, const string &);
上述函数指针pf:bool (*pf)(const string &, const string &);
使用函数指针
  • 当把函数名作为一个值使用时,该函数自动的转换成指针,如:
pf = length_compare <=>等价于pf = &length_compare

函数指针形参
  • 函数类型不能定义为形参,但是形参可以是指向函数的指针;
  • 函数作为实参使用时,会自动的转换成函数指针;
    typedef bool Func(const string &, const string &) // Func是函数类型; typedef bool (*FuncP)(const string &, const string &) // FuncP是函数指针类型;

    typedef decltype(length_compare) Func2// Func2是函数类型; typedef decltype(length_compare) *Func2P // Func2是函数指针类型;

    注意decltype(length_compare)返回的是函数类型,而不是函数指针类型;
using FTtype = int(int,int); //函数类型 typedef int (*pf)(int, int); //函数指针int func(int a, int b){return a+b; } void print(int a, int b, FTtype fn){ // 编译器将其隐式转化成函数指针 cout << fn(a,b) << endl; }int main() { print(1,2,func); cout << typeid(FTtype).name() << endl; // FiiiE cout << typeid(func).name() << endl; // FiiiE cout << typeid(decltype(func)).name() << endl; // FiiiE cout << typeid(pf).name() << endl; // PFiiiE return 0; }

  • 下面两个声明语句是同一个函数,因为编译器会自动的将FTtype 转换成函数指针类型。
    void print(int a, int b, FTtypefn); void print(int a, int b, pf fn);

返回指向函数的指针
虽然不能返回一个函数,但是能返回执行函数类型的指针。和函数参数不同,编译器不会自动地将函数返回类型当作指针类型处理,必须显示的将返回类型指定为指针。如:
using F = int(int*, int); using PF = int(*)(int*,int); Ff1(int); //错误: F是函数类型 PFf1(int); //正确: PF是函数指针类型

f1也可以写出下面两种形式:
int (*f1(int))(int*, int); auto f1(int)->int(*)(int*, int);

    推荐阅读