7

因此,基于粗略的搜索,我已经知道从构造函数调用虚函数(纯函数或其他函数)是不行的。我已经重组了我的代码以确保我没有这样做。虽然这会导致我的类的用户在他们的代码中添加一个额外的函数调用,但这真的没什么大不了的。也就是说,他们现在不是在循环中调用构造函数,而是调用函数,这(实际上!)提高了代码的性能,因为我们没有每次都构建和销毁相关对象的内务管理。

然而,我偶然发现了一些有趣的东西......

在抽象类中,我有这样的东西:

// in AbstractClass.h:
class AbstractClass {
 public:
  AbstractClass() {}
  virtual int Func(); //user can override
 protected:
  // Func broken up, derived class must define these
  virtual int Step1() = 0;
  virtual int Step2() = 0;
  virtual int Step3() = 0;
// in AbstractClass.cpp:
int AbstractClass::Func() {
  Step1();
  // Error checking goes here
  Step2();
  // More error checking...
  // etc...
}

基本上,纯虚函数大部分时间都遵循一个通用结构,但如果它们不遵循,则 Func() 是虚拟的,并允许派生类指定顺序。但是,每个步骤都必须在派生类中实现。

我只是想确保我在这里没有做错任何事情,因为 Func() 函数调用了纯虚拟函数。也就是说,使用基类,如果调用 StepX(),就会发生不好的事情。然而,通过创建一个派生对象然后在该派生对象上调用 Func()(例如 MyDerivedObject.Func();)来使用该类,该派生对象应该正确地重载所有纯虚函数。

按照这种方法,我有什么遗漏或做错了吗?谢谢您的帮助!

4

3 回答 3

5

Func 调用的是虚拟的,而不是纯虚拟的。您必须使用范围运算符限定调用,即 AbstractClass::Step1() 才能调用 THAT(虚拟纯)函数。既然你不是,你总是会得到派生类的实现。

于 2013-07-02T01:41:46.307 回答
1

基类中的虚函数使派生类能够覆盖它。但似乎事情到此为止了。

但是如果基类虚函数是纯的,那会强制派生类实现该函数。

于 2013-12-11T00:43:58.250 回答
-1

作为旁注,您可以将 Step1、Step2、Step3 方法设为私有,这样编译器就会阻止您直接调用它们。

于 2014-06-09T07:45:04.100 回答