在C++中调用受保护的虚拟方法
calling a protected virtual method in C++
可能重复:
在基类构造函数中调用虚拟方法
调用构造函数内部的虚拟函数
如何从C++中的构造函数调用受保护的虚拟方法?
class Foo
{
Foo(){
printStuff(); // have also tried this->printStuff()
}
protected:
virtual void printStuff() {}
}
class ExtendedFoo : public Foo {
protected:
virtual void printStuff() { cout << "Stuff" << endl;}
}
...
ExtendedFoo exFoo; // should print "Stuff"
从构造函数调用受保护的函数没有问题-只需执行即可。然而,您似乎想要的是调用它的具体派生类实现,例如ExtendedFoo,因为它是虚拟的-对吧?这是不可能的,因为在Foo构造函数中,正在创建的对象仍然是Foo类型,而不是ExtendedFoo,因此不能进行虚拟调度。如果受保护的函数不是纯虚拟的,则调用Foo实现,即构造函数将调用类自己的实现。
请考虑,当调用基本构造函数时,实际构造函数仍然没有,因此对象不是完全形成的。
如果你的物体还没有成形,你就不能指望它能正确地行动。
请阅读:
- 在构建或销毁过程中永远不要调用虚拟函数
- [10.7]您应该在构造函数中使用this指针吗
您可以,但您将获得Foo
的实现,因为ExtendedFoo
尚未构造。这是有定义的。
类似的问题:C++设计模式:多种方式加载文件
问题更改后不推荐使用的答案:
如果它在ExtendedFoo中受到保护,则不能从ExtendFoo 违反了功能的保护级别。 http://publib.boulder.ibm.com/infocenter/lnxpcomp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8l.doc%2Flanguage%2Fref%2Fcplr129.htmexFoo.printStuff();
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义