zoukankan      html  css  js  c++  java
  • 继承权限问题

    继承权限分为public protected private,其权限见下表:

         特征       公有继承         保护继承           私有继承      
    父类公有成员继成   派生类公有成员      派生类保护成员        派生类私有成员

    父类保护成员继成   派生类保护成员      派生类保护成员        派生类私有成员

    父类私有成员继成   只能通过基类接口访问   只能通过基类接口访问     只能通过基类接口访问

    当继承之后,那么子类对象对父类成员的访问权限又是样的呢?我们可以看如下代码:

    #include <iostream>
    using namespace std;
    class Base
    {
    public:
        void base_foo (){}
    protected:
        void base_goo(){}
    private:
        void base_hoo(){}
    };
    
    class Derived1:private Base
    {
    public:
        void derived1_foo()           {base_foo ();    }   
        void derived1_goo()        {base_goo();        }    
     //   void derived1_hoo()      {base_hoo();        } // error, inaccessible    
    };
    
    class Derived2:protected Base
    {
    public:
    
        void derived2_foo()           {base_foo ();    }   
        void derived2_goo()        {base_goo();        }    
    //   void derived1_hoo()       {base_hoo();        }  // error, inaccessible     
    };
    
    class Derived3:public Base
    {
    public:
        void derived3_foo()           {base_foo ();    }   
        void derived3_goo()        {base_goo();        }    
    //    void derived1_hoo()      {base_hoo();        }  // error, inaccessible   
    };
    
    int main( int argc, char* argv[])
    {
        Derived1 d1;
        d1.base_foo();//error,cannot access
        d1.base_goo();//error,cannot access
        d1.base_hoo();//error,cannot access
        Derived2 d2;
        d2.base_foo();//error,cannot access
        d2.base_goo();//error,cannot access
        d2.base_hoo();//error,cannot access
        Derived3 d3;
        d3.base_foo();//ok 
        d3.base_goo();//error,cannot access
        d3.base_hoo();//error,cannot access
    
    }

    由此可见,只有共有继承的子类对象能够访问父类的共有成员,其余的都会报错。

  • 相关阅读:
    跟KingDZ学HTML5之三 画布Canvas
    跟KingDZ学HTML5之七 探究Canvas之各种特效
    跟KingDZ学HTML5之八 HTML5之Web Save
    Aptana Studio 3 如何汉化,实现简体中文版
    跟KingDZ学HTML5之十一 HTML5 Form 表单新元素
    跟KingDZ学HTML5之九 HTML5新的 Input 种类
    跟KingDZ学HTML5之十二 HTML5 Form 表单元素新增属性
    跟KingDZ学HTML5之十三 HTML5颜色选择器
    SSL协议运行机制
    门面模式 到 socket
  • 原文地址:https://www.cnblogs.com/mu-tou-man/p/3925500.html
Copyright © 2011-2022 走看看