文章目录
- 代码准备
- 测试演示
- 注意事项
- 成员函数类型申明
- 测试演示
- 总的打印输出
代码准备
头文件:Calc.h
#pragma onceclass Calc
{
public:int add(int,int);//函数声明static int sub(int,int);//函数声明
public:int b;//定义了一个成员变量static int a;//声明了一个静态成员变量,注意这里不是定义,静态成员变量的定义必须在类的定义的外部
};
//int Calc::a = 10;//不要把静态成员变量的定义写到头文件里,否则在其他多个源文件引入此头文件时,会报定义重复
//非类中的普通函数的声明
void normal_fun(int k);
源文件 Calc.cpp
#include "Calc.h"
int Calc::a = 0;//在源文件中定义静态成员变量并初始化
int Calc::add(int i, int j)//定义函数
{ return i + j;
}
int Calc::sub(int i, int j)//定义函数
{return i - j;
}
测试演示
测试代码: test.cpp
#include <iostream>
using namespace std;
#include "Calc.h"//非类中的普通函数的定义
void normal_fun(int k) {cout << __func__ << endl;
}//定义一个命名空间MyNs
namespace MyNs {//声明一个普通函数void normal_fun_2(int k);
}
//命名空间内的函数的定义
void MyNs::normal_fun_2(int k)
{cout << __func__ << endl;
}int main(int argc, char* argv[])
{//打印Calc类成员函数的地址printf("add函数的地址:%p\n", &Calc::add);//打印Calc类静态成员函数的地址printf("sub函数的地址:%p\n", &Calc::sub);//打印Calc类静态成员变量的地址printf("变量a的地址:%p\n", &Calc::a);//打印非类中的全局普通函数的地址printf("normal_fun_1函数地址:%p\n", normal_fun_1);//打印命名空间中的普通函数的地址printf("normal_fun_2函数地址:%p\n", MyNs::normal_fun_2);
}
注意事项
注意获取一个类中成员函数指针的语法要求很严格:
1.必须有限定符:例如&add或者&sub不对。即使在类Calc的作用域内也不行。
2.必须使用取地址符号:例如直接写ClassName::add不行。(虽然普通函数指针可以这样) 所以,必须要这样写:&ClassName::add。
3.不能使用括号:例如&(ClassName::add)不对,但是经测试发现这样也是可以的。
4.普通函数可以直接用函数名当作函数地址 或者 命名空间里的函数通过NameSpace::normal_fun_2的方式,前面不需要加&。
成员函数类型申明
可以像普通函数一样采用typedef或者using 运算符将函数指针类型重命名,这样更好看一些。普通函数指针的申明
void test() {int (Calc::*addFun)(int,int) = &Calc::add;//addFun就是成员函数add的函数指针Calc c; //.*的用法,经由对象调用 即对象动态调用符号.*int ret = (c.*addFun)(7, 6); cout << __func__ << " ret=" << ret<< endl; //13Calc* pc = &c; //->*的用法,经由对象指针调用 即对象指针动态调用符号->*ret = (pc->*addFun)(6,3); cout << __func__ << " ret=" << ret << endl; //9
}
void test1() {int (Calc:: *addFun)(int, int);//定义了一个Calc类下含有两个int型参数,返回类型为int的 成员函数指针addFuntypedef int (Calc:: *Pmt)(int, int);//成员函数指针类型的别名为Pmt//using Pmt = int (Calc::*)(int, int);//等价于上面的typedef定义。addFun = &Calc::add;Pmt pmt = &Calc::add;Calc c;int ret1 = (c.*addFun)(6,5);cout << __func__ << " ret1=" << ret1 << endl;//11int ret2 = (c.*pmt)(6, 6);cout << __func__ << " ret2=" << ret2 << endl;//12
}
测试演示
int main(int argc, char* argv[])
{test();test1();
}