函數指針是通過指向函數的指針間接調用函數。函數指針可以實現對參數類型、參數順序、返回值都相同的函數進行封裝,是多態的一種實現方式。由於類的非靜態成員函數中有一個隱形的this指針,因此,類的成員函數的指針和一般函數的指針的表現形式不一樣。
1、指向一般函數的指針
函數指針的聲明中就包括了函數的參數類型、順序和返回值,只能把相匹配的函數地址賦值給函數指針。為了封裝同類型的函數,可以把函數指針作為通用接口函數的參數,並通過函數指針來間接調用所封裝的函數。
下面是一個指向函數的指針使用的例子。
代碼如下:
#include <iostream.h>
/*指向函數的指針*/
typedef int (*pFun)(int, int);
int Max(int a, int b)
{
return a > b ? a : b;
}
int Min(int a, int b)
{
return a < b ? a : b;
}
/*通用接口函數,實現對其他函數的封裝*/
int Result(pFun fun, int a, int b)
{
return (*fun)(a, b);
}
void main()
{
int a = 3;
int b = 4;
cout<<"Test function pointer: "<<endl;
cout<<"The maximum number between a and b is "<<Result(Max, a, b)<<endl;
cout<<"The minimum number between a and b is "<<Result(Min, a, b)<<endl;
}
2、指向類的成員函數的指針
類的靜態成員函數采用與一般函數指針相同的調用方式,而受this指針的影響,類的非靜態成員函數與一般函數指針是不兼容的。而且,不同類的this指針是不一樣的,因此,指向不同類的非靜態成員函數的指針也是不兼容的。指向類的非靜態成員函數的指針,在聲明時就需要添加類名。
下面是一個指向類的成員函數的指針的使用的例子,包括指向靜態和非靜態成員函數的指針的使用。
代碼如下:
#include <iostream.h>
class CA;
/*指向類的非靜態成員函數的指針*/
typedef int (CA::*pClassFun)(int, int);
/*指向一般函數的指針*/
typedef int (*pGeneralFun)(int, int);
class CA
{
public:
int Max(int a, int b)
{
return a > b ? a : b;
}
int Min(int a, int b)
{
return a < b ? a : b;
}
static int Sum(int a, int b)
{
return a + b;
}
/*類內部的接口函數,實現對類的非靜態成員函數的封裝*/
int Result(pClassFun fun, int a, int b)
{
return (this->*fun)(a, b);
}
};
/*類外部的接口函數,實現對類的非靜態成員函數的封裝*/
int Result(CA* pA, pClassFun fun, int a, int b)
{
return (pA->*fun)(a, b);
}
/*類外部的接口函數,實現對類的靜態成員函數的封裝*/
int GeneralResult(pGeneralFun fun, int a, int b)
{
return (*fun)(a, b);
}
void main()
{
CA ca;
int a = 3;
int b = 4;
cout<<"Test nonstatic member function pointer from member function:"<<endl;
cout<<"The maximum number between a and b is "<<ca.Result(CA::Max, a, b)<<endl;
cout<<"The minimum number between a and b is "<<ca.Result(CA::Min, a, b)<<endl;
cout<<endl;
cout<<"Test nonstatic member function pointer from external function:"<<endl;
cout<<"The maximum number between a and b is "<<Result(&ca, CA::Max, a, b)<<endl;
cout<<"The minimum number between a and b is "<<Result(&ca, CA::Min, a, b)<<endl;
cout<<endl;
cout<<"Test static member function pointer: "<<endl;
cout<<"The sum of a and b is "<<GeneralResult(CA::Sum, a, b)<<endl;
}