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

pointer to member and using virtual functions

本文关键字:函数 指针 成员      更新时间:2023-10-16

我想用指针填充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;
}   

我认为这个问题是标准中的一个网站。没有原因:

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;