成员函数指针数组:当控件到达指向成员函数的指针时获取 0xcccccccc

Posted

技术标签:

【中文标题】成员函数指针数组:当控件到达指向成员函数的指针时获取 0xcccccccc【英文标题】:Array of member function pointers : Getting 0xcccccccc when control reached pointer to member function 【发布时间】:2009-07-07 12:51:31 【问题描述】:

执行以下代码时出现错误访问冲突:

void NoAction()  

    (*m_psStateMachine[0][0])(); 

class CXcp

public: 
    CXcp()
    CXcp(WORD wXcpProtocol);
    ~CXcp();

private:
    void (*m_psStateMachine[10][16])(); 

public:     
    // Action Methods from State M/c Table in the RFC//     
    void IrcScr_6()
    void IrcStr_4()
    void TldIrcStr_4()
    void Tls_1()
    void Tld_1()
    void Tlf_0()
    void Tld() 
    void Str_4()
    void Str_5()
    void Scr_6()
    void Scr_8()
    void Tlf_2()
    void Tlf_3()
    void Tlf_3p()
    void Sta_2()
    void IrcScrSca_8()
    void Sca_8()
    void ScaTlu_9()
    void TldScrSca_8()
    void Scn_6()
    void Scn_7()
    void TldScrScn_6()
    void IrcScrScn_8()
    void Irc_7()
    void Scr_6x()
    void IrcTlu_9()
    void TldScr_6x()
    void Sta_3()
    void IrcScr_8()
    void Sta_4()
    void Sta_5()
    void Sta_6()
    void TldZrcSta_6()
    void TldScr_6()
    void Scj_2()
    void Scj_3()
    void Scj_4()
    void Scj_5()
    void Scj_6()
    void Scj_7()
    void Scj_8()
    void Scj_9()
    void TldIrcStr_5()
    void Ser_9()

    void NoAction() 
    
        (*m_psStateMachine[0][0])();
    
    void Initial()  
    void Starting() 
    void Closed()   
    void Stopped()  
    void Closing()  
    void Stopping() 
    void ReqSent()  
    void AckRecvd() 
    void AckSent()  
    void Opened()   
;

CXcp::CXcp(WORD wXcpProtocol)



// Kernel of the PPP the State M/c : Initialization Here 
    void (CXcp :: *m_psStateMachine[10][16])() = 
    
/*         State                                     
             0          1             2         3          4          5         6         7          8           9          
Events |  INITIAL    STARTING      CLOSED     STOPPED    CLOSING    STOPPING   Req-Sent  Ack-Rcvd   Ack-Sent    OPENED */

/*Up*/     &CXcp::Initial, &CXcp::IrcScr_6, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction,

/*Down*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Initial, &CXcp::Tls_1, &CXcp::Initial, &CXcp::Starting, &CXcp::Starting, &CXcp::Starting, &CXcp::Starting, &CXcp::Tld_1,

/*Open*/   &CXcp::Tls_1, &CXcp::Starting, &CXcp::IrcScr_6, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::ReqSent, &CXcp::AckRecvd, &CXcp::AckSent, &CXcp::Opened,

/*Close*/  &CXcp::Initial, &CXcp::Tlf_0, &CXcp::Closed, &CXcp::Closed, &CXcp::Closing, &CXcp::Closing, &CXcp::IrcStr_4, &CXcp::IrcStr_4, &CXcp::IrcStr_4, &CXcp::TldIrcStr_4,

/*TO+*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::Str_4, &CXcp::Str_5, &CXcp::Scr_6, &CXcp::Scr_6, &CXcp::Scr_8, &CXcp::NoAction,

/*TO-*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::NoAction, &CXcp::Tlf_2, &CXcp::Tlf_3, &CXcp::Tlf_3p, &CXcp::Tlf_3p, &CXcp::Tlf_3p, &CXcp::NoAction,

/*RCR+*/  &CXcp::NoAction, &CXcp::NoAction, &CXcp::Sta_2, &CXcp::IrcScrSca_8, &CXcp::Closing, &CXcp::Stopping, &CXcp::Sca_8, &CXcp::ScaTlu_9, &CXcp::Sca_8, &CXcp::TldScrSca_8,

/*RCR-*/  &CXcp::NoAction, &CXcp::NoAction, &CXcp::Sta_2, &CXcp::IrcScrSca_8, &CXcp::Closing, &CXcp::Stopping, &CXcp::Scn_6, &CXcp::Scn_7, &CXcp::Scn_6, &CXcp::TldScrScn_6,

/*RCA*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Sta_2, &CXcp::IrcScrScn_8, &CXcp::Closing, &CXcp::Stopping, &CXcp::Irc_7, &CXcp::Scr_6x, &CXcp::IrcTlu_9, &CXcp::TldScr_6x,

/*RCN*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Sta_2, &CXcp::Sta_3, &CXcp::Closing, &CXcp::Stopping, &CXcp::IrcScr_6, &CXcp::Scr_6x, &CXcp::IrcScr_8, &CXcp::TldScr_6x,

/*RTR*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Sta_2, &CXcp::Sta_3, &CXcp::Sta_4, &CXcp::Sta_5, &CXcp::Sta_6, &CXcp::Sta_6, &CXcp::Sta_6, &CXcp::TldZrcSta_6,

/*RTA*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Closed, &CXcp::Stopped, &CXcp::Tlf_2, &CXcp::Tlf_3, &CXcp::ReqSent, &CXcp::ReqSent, &CXcp::AckSent, &CXcp::TldScr_6,

/*RUC*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Scj_2, &CXcp::Scj_3, &CXcp::Scj_4, &CXcp::Scj_5, &CXcp::Scj_6, &CXcp::Scj_7, &CXcp::Scj_8, &CXcp::Scj_9,

/*RXJ+*/  &CXcp::NoAction, &CXcp::NoAction, &CXcp::Closed, &CXcp::Stopped, &CXcp::Closing, &CXcp::Stopping, &CXcp::ReqSent, &CXcp::ReqSent, &CXcp::AckSent, &CXcp::Opened,

/*RXJ-*/  &CXcp::NoAction, &CXcp::NoAction, &CXcp::Tlf_2, &CXcp::Tlf_3, &CXcp::Tlf_2, &CXcp::Tlf_3, &CXcp::Tlf_3, &CXcp::Tlf_3, &CXcp::Tlf_3, &CXcp::TldIrcStr_5,

/*RXR*/   &CXcp::NoAction, &CXcp::NoAction, &CXcp::Closed, &CXcp::Stopped, &CXcp::Closing, &CXcp::Stopping, &CXcp::ReqSent, &CXcp::AckRecvd, &CXcp::AckSent, &CXcp::Ser_9

    ;


CXcp::~CXcp()




int main(void)

    CXcp oXcp(10);
    oXcp.NoAction();
    return 0;

我们将不胜感激。

提前致谢

【问题讨论】:

编辑您的问题以包含相关代码。 【参考方案1】:

好吧,你不要初始化这个成员:

void (*m_psStateMachine[10][16])();

您所做的是在构造函数中创建一个本地数组,并初始化 that。那只能失败。把成员改成这个

void (CXcp::*m_psStateMachine[10][16])();

在构造函数中,将本地数组复制到成员中(最好从本地数组的名称中删除 m_ 前缀,以免与实际的成员数组混淆)。

for(int i = 0; i < 10; i++)
  for(int j = 0; j < 16; j++)
     this->m_psStateMachine[i][j] = stateMachine[i][j];

或者,您可以单独分配每个元素,如果您喜欢巨大的痛苦:) 然后您可以使用另一种语法调用成员指针数组

(this->*m_psStateMachine[0][0])();

当然,某处你需要告诉它在哪个对象上调用它。

【讨论】:

废话 :) 当然是 copy(m_psStateMachine, ....);不适用于多维数组:) 已更正。 最好不要在局部变量上使用 m_ 成员前缀 - 正是这种混淆首先导致了问题。出于这个原因,对本地使用 m_ 前缀应该是编译器警告。【参考方案2】:

该代码中有许多错误:

    代码试图将方法指针存储到m_psStateMachine,它被声明为“指向返回void的函数的指针数组”:

    私人: 无效 (*m_psStateMachine[10][16])();

    稍后您使用方法指针创建一个局部/静态变量:

    void (CXcp :: *m_psStateMachine[10][16])() = ...
    这对你的方法中可见的m_psStateMachine 没有影响,你必须使用::m_psStateMachine

    当通过方法指针数组调用方法时,您必须告诉编译器要为this 使用哪个值,就像在(this-&gt;*m_psStateMachine[0][0])() 中一样。

我建议将方法指针数组的声明替换为类似于

的内容
class ... 
    static const void (CXcp::*m_psStateMachine[10][16])();
    ...
;
const void (CXcp::*CXcp::m_psStateMachine[10][16])() =  ... ;

【讨论】:

以上是关于成员函数指针数组:当控件到达指向成员函数的指针时获取 0xcccccccc的主要内容,如果未能解决你的问题,请参考以下文章

指向基类中成员函数的指针数组

无法在类的析构函数中删除指向数组的成员指针

指向成员函数的函数指针

C ++创建指向标头内所有公共静态成员函数的指针数组,然后使用它

一图总结C++中关于指针的那些事

将指向 int 数组的指针传递给成员函数,错误:数组下标的无效类型“int [int]”