我希望类 C 从类 A 继承其虚函数,类 D(类 C 中的嵌套类)继承类 B(类 A 中的嵌套类)其数据字段,这就是我所拥有的。
文件1.h
class A{
public:
virtual void foo()=0;
class B{
public:
int data;
};
};
Run Code Online (Sandbox Code Playgroud)
文件2.h
class C : public A{
public:
class D : public A::B{
};
};
Run Code Online (Sandbox Code Playgroud)
文件2.cpp
void C::foo(){//code}
C::D::D():data(0){//Bad initialization list, error being data is not a member of C::D even it should inherits from its base class
data = 0; //good! compiler can see data is a member of A::B,and C::D inherits from it
}
Run Code Online (Sandbox Code Playgroud)
我有两个问题,第一个问题是我正在采取正确的方法来实现这种继承。其次,正如我所评论的,为什么编译器可以在手动初始化过程中看到数据来自 A::B 而不是在初始化列表中?它们不应该在同一个范围内吗?非常感谢
编辑1:
因此,如果类 C::D(foo) 不直接继承自 A::B(foo),但 C 继承自 A,我的看法是,由于 C 继承自 A 及其所有公共字段,包括其内部类 A ::B(foo), D(foo) 与 A::B(foo) 具有完全相同的名称,并且是 C 的内部类,如下所示,即两个内部类都使用 foo
class A{
public:
class foo{
public:
int data;
};
};
class C : public A{
public:
class foo{
};
};
Run Code Online (Sandbox Code Playgroud)
当我直接调用 C::foo 时,编译器会感到困惑吗?因为有两个构造函数的名称在范围内?或者它选择调用“最近的”一个,例如 C:foo? 而不是沿着继承链向上爬?非常感谢
是的,你的做法是实现这种继承的正确方法。
初始化列表用于控制传递给构造函数的参数。您可以将参数传递给 B 的构造函数,但不能直接初始化 B 的成员(这是其构造函数的工作)。如果没有为基类或成员指定构造函数,则使用默认构造函数。在您的情况下,向 B 添加一个构造函数来实现您想要的。
class A {
public:
class B{
public:
B(int i) : data(i) {}
int data;
};
};
class C : public A {
class D : public A::B {
};
};
C::D::D() :B(0) { }
Run Code Online (Sandbox Code Playgroud)| 归档时间: |
|
| 查看次数: |
19388 次 |
| 最近记录: |