“成员函数指针”是否可以指向同一个类中的成员函数

时间:2012-08-29 09:51:59

标签: c++ pointers function-pointers

代码

class cat{

        public:
           void walk(){
                printf("cat is walking \n");
           }

           void myAbc(){
               void (*pKoo)();
               pKoo = &this->walk;
           }

          void myDef(){
               void(cat::*pFoo)();
               pFoo = &this->walk;
          }
        }

    };

结果

  1. void(* pKoo)(); - 没问题
  2. pKoo =& this-> walk; - 编译错误
  3. 空隙(猫:: * PFOO)(); - 没问题
  4. pFoo =& this-> walk; - 编译错误;
  5. 问题

    • 为什么没有2不可能?如果不可能,那么1号的用途是什么?
    • 为什么没有4不可能?如果不可能,那么No 3有什么用?

    请帮助进行概念性解释。谢谢

2 个答案:

答案 0 :(得分:2)

void (*pKoo)();                
pKoo = &this->walk; 

给出错误,因为函数指针类型与您为其分配地址的函数类型不匹配。

walk()的类型是:

void (cat::*)(void);

void(cat::*pFoo)();
pKoo = &this->walk; 

应该是:

pKoo = &cat::walk;

方法walk属于类cat,而不属于该类的任何特定实例。因此,您无法使用this->walk(),但您需要使用类名限定方法名称。

答案 1 :(得分:2)

  

为什么没有2不可能?

我的编译器给出了一条错误消息:

cannot convert ‘void (cat::*)()’ to ‘void (*)()’ in assignment

意味着您无法将指向成员函数的指针转换为指向函数的指针。它们是不兼容的类型;可以直接调用指向函数的指针,而需要将指向成员函数的指针应用于对象。因此,您指定的类型必须是指向成员函数的指针,或void (cat::*)();,正如您在3中正确使用的那样。

  

如果不可能,那么1号的用途是什么?

它用于存储指向静态或非成员函数的指针。

  

为什么没有3不可能?

(我假设你的意思是4,而不是3.)我的编译器给出了一条错误信息:

ISO C++ forbids taking the address of a bound member function to form a 
pointer to member function.  Say ‘&cat::walk’

出于某种原因,您不允许使用对象(或指针)获取成员函数的地址;你必须使用类名。我们只能推测为什么不允许这样做;也许是因为如果它是虚拟的,或者出于某种其他原因,应该选择哪种覆盖并不完全清楚。

无论原因是什么,请使用允许的语法:pFoo = &cat::walk;