2

我对 C++ 重新定义有疑问。我在派生类中分配内存,所以我需要在基类中保留这个内存。因此,我需要考虑 Base 类中的属性与 Derived 类中的属性相同,我不知道这在 C++ 中是否可行。

class Base {
 protected:
  float * a;
  Base() {}
 public:
  virtual void reset() {
    a = 0;
  }  
  virtual void exec() {
    printf("Memory a: %x\n",a);
  }
};  

class Derivada: virtual public Base {
 protected:
  float * a;
  Derivada() {}
  virtual void reset() {
    a = new float[256];
  }
};

int main() {
  Derivada *hija= new Derivada();    
  hija->reset();
  hija->exec();
  delete hija;
}

我真的需要做重载,因为这是我真正问题的一个例子。对于 CVS 的两个不同的类 Base,我的两个分支中的每个分支一个,我有相同的测试(派生一个主代码)。

在一个 Base 类中,我有这个属性,而在另一个 Base 类中,我没有这个属性,所以我必须将它放在 Derived 类中进行编译。

我不想制作两个不同的测试代码,所以我需要覆盖属性

4

2 回答 2

3

你可以做这样的事情(但需要 C++11):

#include <type_traits>

// A way to check for 'attr' data member presence/absence using SFINAE
template<class T> constexpr auto missing_attr(T) -> decltype(T::attr, bool())
{
  return false;
}
constexpr bool missing_attr(...) { return true; }

struct Base { /* There might be (or not) a float data member 'attr' */ };

template<bool> struct Inject;
template<> struct Inject<true> { float attr = 0.0; };
template<> struct Inject<false> {};

struct Derived : public Base, protected Inject<missing_attr(Base())>
{
  void do_something_with_attr()
  {
    // Derived has only one 'float attr' (it can be from Base or from Inject).
    a *= a;
  }
};

还有其他方法可以检测数据成员是否存在,例如成员检测成语(C++03 兼容)。

于 2014-03-31T11:22:41.400 回答
3

不要重新声明派生类的成员。“受保护”一词确保了可见性。

如果您重新声明该成员,您将拥有一个新成员。这称为阴影。见,例如

于 2014-03-31T08:10:21.500 回答