使用访问修饰符的 C++ 继承
c++ inheritance with access modifiers
我有这个代码片段
#include <iostream>
using namespace std;
class Polygon
{
public:
int publicmemberPolygon;
private:
int privatememberPolygon;
protected:
int protectedmemberPolygon;
};
class Square : public Polygon
{
public:
int Getter();
};
int Square::Getter()
{
return privatememberPolygon;
}
int main()
{
}
问题是,为什么私有成员Polygon是不可接受的? 不是吗,当你有一个派生类时,它的所有成员/函数都被复制了? 谢谢
否,当您从基类公开派生时,派生类只能访问其public
和protected
成员。您也可以阅读此常见问题解答。
请参阅此示例:
class Base
{
public:
void setPrivate(int p)
{
m_private = p;
}
public:
int m_public;
protected:
int m_protected;
private:
int m_private;
};
class Derived : public Base
{
public:
void f()
{
m_public = 0; // Can access public member of base class
m_protected = 0; //Can access protected member of base class
m_private = 0; //Compiler error- Can not access private member of base class
}
};
int main() {
Derived d;
d.setPrivate(10); //m_private is still part of the derived class. Hence can call setPrivate
return 0;
}
成员不会"复制"到派生类。 派生类包含基类的子对象,几乎与具有成员变量相同。
事实上,组合和非公有继承通常被认为是解决同一问题的两条路径。
非公共继承的一个微不足道的区别是,基本子对象的成员不必通过对象名称来限定才能找到它们,它们是其中的一部分(除非你有钻石继承,哎呀! 使用公共继承时,还可以从对派生类的指针或引用隐式转换为指向基类的指针或成员。
更大的区别是继承允许覆盖虚函数,而组合则不允许。
protected
成员(和基础)在归根结底实际上是无用的,因为它们抑制了组合,而没有像virtual
那样提供真正的好处。 有时,当虚拟函数已经使继承成为必要时,会使用它们。
当您公开继承时,只有公共和受保护的数据成员才能在继承中访问。
相关文章:
- 继承函数的重载解析
- 继承期间显示未知行为的子类
- 头文件-继承c++
- 为什么在保护模式下继承升级不起作用
- 通过继承类使用来自不同命名空间的运算符
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 混合组合和继承的C++问题
- 继承:构造函数,初始化C++11中基类的类C数组成员
- 从类继承时,继承的类是否会通过父类重新定义继承的变量
- 公共与私人继承
- 如何创建从同一类继承的不同对象的向量
- 如何从另一个文件继承私有成员变量和公共函数
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 带有继承的C++工厂
- 我应该避免多重实现继承吗
- C++继承更改成员
- 从具有默认值的部分指定模板类继承时发生SWIG错误,具有不带默认值的正向声明
- 关于C++中具有多重继承"this"指针的说明
- 尝试使用继承和模板实现CRTP.Visual Studio正在生成编译器错误
- 如何在QT Creator上将QWidget声明为继承类的对象