指向成员和使用虚函数的指针

时间:2013-05-14 07:36:13

标签: c++ c++11 pointer-to-member

我想用一个指针来填充一个constexpr表,以便稍后调用指针。给出的示例仅显示一个条目。

我遇到两个问题:

1)我不可能找到一个正确的语法来编写一个能够初始化为派生类对象的成员类对象的指针。

2)我无法使用指针调用虚函数。

#include <iostream>

using namespace std;

class State { public: virtual void Do() const {} };
class S1: public State { public: virtual void Do() const { cout << "S1 Do" << endl; } };
class S2: public State { public: virtual void Do() const { cout << "S2 Do" << endl; } };

class A 
{   
    public:

        S1 s1; 
        S2 s2; 
};  

class B
{   
    private:
        static constexpr A a{};
        static constexpr State A::*state { &A::S2 }; // < do not work! 

    public:

        void Do() const
        {   
            (a.*state).Do();    // is it possible to have a pointer to any State class to call virtual functions?  
        }   
};  

constexpr A B::a;


int main()
{   
    B b;
    b.Do();
    return 0;
}   

1 个答案:

答案 0 :(得分:2)

我认为问题是标准中的问题。没有 原因:

State A::*state = static_cast<State A::*>( &A::s1 );

应该不起作用,但是允许它的措辞在 标准。有许多解决方法:最明显的 将有一个访问函数返回State* 每个成员变量,并使用指向函数的指针:

class A
{
public:
    S1 s1;
    State* getS1() { return &s1; }
    S1 s2;
    State* getS2() { return &s2; }
};

class B
{
    static A a;
    static State* (A::*getState)();
public:
    void Do() const
    {
        (a.*getState)()->Do();
    }
}

State* (A::* B::getState)() = &A::getS1;