【C++】继承中的隐藏与覆盖

没有访问控制符时默认为私有继承

当基类中的某个函数有若干个重载版本,继承类中也实现了该函数的某个重载版本时,参数完全相同的基类版本被覆盖,基类的其他版本被隐藏

 

1.若要在继承类中使用基类的被覆盖方法,用::

  如B继承A, B b;   b.A::fun(); 调用的就是被覆盖的基类方法

2.若要在继承类中使用基类的被隐藏方法:

   b.A::fun(1,,2); 调用的就是被隐藏的基类方法

       在B中声明 using A::fun;

3.在私有继承的派生类中把基类的公有函数转变为公有函数

  在B中的public中声明 A::fun;  //不提倡

      在B中的public中声明 using A::fun;

 

#include <iostream>
using namespace std;

class A
{
public:
    void fun()
    {
        cout << "A fun()" << endl;
    }
    void fun(int x)
    {
        cout << "A fun(int x)" << endl;
    }
    void fun(int x, int y)
    {
        cout << "A fun(int x, int y)" << endl;
    }
};

class B:public A
{
public:
    void fun()  
    {
        cout << "B fun()" << endl;
        A::fun();    //在派生类中使用基类被覆盖的方法
    }
};

class C:public A
{
public:
    using A::fun;  //使用using 把A的被隐藏版本包含进来 但是被覆盖的版本无法被包含进来
    void fun()  
    {
        cout << "C fun()" << endl;
    }
};

class D:private A  //私有继承
{
public:
    using A::fun; //在私有继承时把A的公有函数改为公有
};

class E:private A  //私有继承
{
public:
    A::fun; //在私有继承时把A的公有函数改为公有(不提倡这种)
};
int main()
{
    A a;
    B b;
    C c;
    D d;
    E e;
    a.fun();       //输出A的版本
    a.fun(1);
    a.fun(1,2);
    cout << "-----------" << endl;
    b.fun();       //输出B的版本 A的版本被覆盖
    //b.fun(1);    错误,该版本被隐藏
    //b.fun(1,2);  错误,该版本被隐藏 
    cout << "-----------" << endl;
    b.A::fun();    //通过作用域运算符,得到A的版本
    b.A::fun(1);   //A的版本
    b.A::fun(1,2); //A的版本
    cout << "-----------" << endl;
    c.fun();      //C的版本
    c.fun(1);     //A的版本
    c.fun(1,2);   //A的版本
    cout << "-----------" << endl;
    d.fun();     //A的版本
    d.fun(1);    //A的版本
    d.fun(1,2);  //A的版本
    cout << "-----------" << endl;
    e.fun();     //A的版本
    e.fun(1);    //A的版本
    e.fun(1,2);  //A的版本


    return 0;
}

 

posted @ 2015-09-06 11:02  匡子语  阅读(411)  评论(0编辑  收藏  举报