成员函数虽然是函数,但是跟一般的函数还是有区别。而如果忽视了这一点就容易导致程序编写上出错,而且难以发现。
定义一个对象时,系统只为数据成员分配空间。那么对于类的成员函数而言,它如何知道函数中提到的数据成员是哪个对象的数据成员呢?……实际上,C++为每个成员函数设置了一个隐藏的指向本类型的指针形参this,它指向当前调用成员函数的对象。成员函数中对对象成员的访问时通过this指针实现的。……因此,当通过对象调用成员函数时,编译器会把相应对象的地址传给形参this。——《C++程序设计思想与方法慕课版》
因此,一个类的成员函数实际上并不只有写出了的几个形参,还有一个指向调用成员函数的对象的指针。这样的函数,在作为函数指针来调用的时候,由于没有调用它的成员对象,是不能用的。
但是静态的成员函数由于没有this指针,可以作为函数指针来使用。
我就是想用成员函数作为函数指针来调用怎么办?
这里提供一个解决方法:
template<class CLASS>
void visit(CLASS &c) {
c.function();
}
就实际上是传入你的类的实例对象,再用这个对象调用成员函数。这个方法不是非常好,要求能实例化并调用这个visit函数的类必须都要有一个名为function的成员函数,这里可以通过对所需的成员函数再次包装实现。
总之,遇到非用成员函数不可的情况,可以用上面这种方法解决。