class Der : public Base
{
virtrul void interface1()
{}
}
class Base
{
Base()
{}
virtrul void interface1()
{}
}
class Der : public Base
{
virtrul void interface1()
{}
}
怎么才能在Base()的构造函数中,调用Der::interface1();
...全文
20638打赏收藏
大家进来看看,怎么才能实现下面的要求。
class Base { Base() {} virtrul void interface1() {} } class Der : public Base { virtrul void interface1() {} } class Base { Base() {} virtrul void interface1() {} } class Der : public Base { virtrul void interface1() {} } 怎么才能在Base()的构造函数中,调用Der::in
5.当一个构造函数被调用时,它做的首要的事情之一是初始化它的V P T R。因此,它只能知道它是“当前”类的,而完全忽视这个对象后面是否还有继承者。 当编译器为这个构造函数产生代码时,它是为这个类的构造函数产生代码- -既不是为基类,也不是为它的派生类(因为类不知道谁继承它)。 所以它使用的V P T R必须是对于这个类的VTABLE。而且,只要它是最后的构造函数调用,那么在这个对象的生命期内, V P T R将 保持被初始化为指向这个VTABLE。但如果接着还有一个更晚派生的构造函数被调用,这个构造函数又将设置V P T R指向它的 V TA B L E,等.直到最后的构造函数结束。V P T R的状态是由被最后调用的构造函数确定的。这就是为什么构造函数调用是从基类到更加派生 类顺序的另一个理由。 但是,当这一系列构造函数调用正发生时,每个构造函数都已经设置V P T R指向它自己的 VVTABLE。如果函数调用使用虚机制,它将只产生通过它自己的VTABLE的调用,而不是最后的VTABLE(所有构造函数被 调用后才会有最后的VTABLE)。