C++:指向虚拟成员函数的单态版本的指针?

gla*_*erl 27 c++ virtual-functions member-function-pointers

在C++中,可以获得指向类的(非静态)成员函数的指针,然后在对象上调用它.如果函数是虚函数,则根据对象的动态类型动态调度调用.通过显式提供包含要使用的版本的范围,也可以(不使用成员指针)以单态方式调用对象的虚拟成员函数.以下代码演示了这一点:

#include <iostream>
using std::cout; using std::endl;

struct Foo
{
    virtual void foo() { cout << 1 << endl; }
};

struct Foo2: public Foo
{
    virtual void foo() { cout << 2 << endl; }
};

int main( int, char** )
{
    Foo *foo = new Foo2;

    void (Foo::*foo_pointer)() = &Foo::foo;

    foo->foo();            // prints 2
    foo->Foo::foo();       // prints 1
    (foo->*foo_pointer)(); // prints 2
}
Run Code Online (Sandbox Code Playgroud)

我想要做的是将两者结合起来,并获得指向成员函数的单态版本的指针; 即,我想要一个指向Foo :: foo的指针,它总是调用foo的基类版本,并打印1,即使它是在Foo2上调用的.但是,我还没有找到办法做到这一点.可能吗?

(除了编写一个新的非虚函数的繁琐的手动方式,它进行单态调用,然后获得指向它的指针.)

Jan*_*dec 10

它可能在GCC中,但它在C++语言扩展部分中记录的方式表明没有可移植的方法来实现它.

你可以做两件事:

  1. 如果您控制该类,请为其创建非虚函数和虚拟包装,当您知道不需要虚拟调度时,只需获取非虚拟调度的地址.
  2. 如果不这样做,请创建一个模板函子,该函数将保存成员指针并执行显式范围调用.