如何用指针调用类的成员函数?可以考虑以下方法:
(1)将需要调用的成员函数设为static类型,如:在前述例子2中,将classTest2成员函数Compare定义前加上static如下(黑体为改变之处):
classTest2{//….intstatic__cdeclCompare(constvoid*elem1,constvoid*elem2)//成员函数。//其他不变}
改变后的代码编译顺利通过。原因是,static类型的成员函数与类是分开的,其函数指针也不包含对象信息,与一般函数指针一致。这种方法虽然简便,但有两个缺点:被调用的函数成员定义内不能出现任何类的成员(包括变量和函数);由于使用了static成员,类在被继承时受到了限制。
(2)使用一个函数参数含有对象信息的static类型的成员函数为中转间接地调用其他成员函数,以例3为例,将类Test3作如下修改(黑体字为修改之处),main()函数不变,则可顺利通过编译:
classTest3{ public: //… voidstatic__cdeclHelper(Test3*test3) { test3->Memberfun2(); } voidMemberfun1(void(*f2)(Test3*)){f2(this);}//将对象信息传给Helper函数。 voidMemberfun2(){printf(%s\n,CallingTest3::Memberfun2OK);}//成员函数2。 voidMemberfun3(){Memberfun1(Helper);} //…};
这种间接方式对成员函数没有任何限制,克服了第一种方法成员函数不能使用任何类的成员的缺点,但由于有static成员,类的继承仍受到制约。
(3)使用一个全程函数(globalfunction)为中转间接调用类的成员函数,仍以例3为例,将代码作如下修改(VC++6.0编译通过):
classTest3;void__cdeclHelper(Test3*test3);classTest3{ public: //… voidMemberfun1(void(*f2)(Test3*)){f2(this);}//成员函数1调用成员函数//2。 voidMemberfun2(){printf(%s\n,CallingTest3::Memberfun2OK);}//成员函数2。 voidMemberfun3(){Memberfun1(Helper);} //…};void__cdeclHelper(Test3*test3){ test3->Memberfun2();};
这个方法对成员函数没有任何要求,但是需要较多的代码。
除上述三种方法外还有其他方法,如,可以在汇编层面上修改代码解决上述问题等,不属于本文范围。