使用访问修饰符的 C++ 继承

c++ inheritance with access modifiers

本文关键字:C++ 继承 访问      更新时间:2023-10-16

我有这个代码片段

    #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是不可接受的? 不是吗,当你有一个派生类时,它的所有成员/函数都被复制了? 谢谢

否,当您从基类公开派生时,派生类只能访问其publicprotected成员。您也可以阅读此常见问题解答。

请参阅此示例:

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那样提供真正的好处。 有时,当虚拟函数已经使继承成为必要时,会使用它们。

当您公开继承时,只有公共和受保护的数据成员才能在继承中访问。