zoukankan      html  css  js  c++  java
  • 多继承

    C++允许为一个派生类指定多个基类,这样的继承结构被称做多重继承,此时派生类有两个或两个以上的直接基类。

    虚基类与二义性

    菱形继承可能会存在二义性

    int main( )
    {
        DC d;
        d.x = 1;       // error C2385: 对"x"的访问不明确
             //可能是"x"(位于基"BC1"中),也可能是"x"(位于基"BC2"中)
        d.BC1::x = 2;   // OK,from BC1
        d.BC2::x = 3;   // OK,from BC2
        d.K = 4;           // error C2385: 对"K"的访问不明确
        d.BC1::K = 5;  // OK,from BC1
        d.BC2::K = 6;  // OK,from BC2
        return 0;
    }
    

    解决方法:采用虚继承,在BC1类和BC2类继承BC0时,其前面加上virtual关键字就可以实现虚拟继承,使用虚拟继承后,当系统碰到多重继承的时候就会先自动加一个BC0的拷贝,当再次请求一个BC0的拷贝时就会被忽略,以保证继承类成员函数的唯一性。

    class BC0
    {
    public:
        int K;
    };
    class BC1 : virtual public BC0
    {
    public:
        int x;
    };
    class BC2 : virtual public BC0
    {
    public:
        int x;
    };
    class DC : public BC1, public BC2
    {
    };
    void main( )
    {
        DC d;       //虚继承使得BC0仅被DC间接继承一份
        d.K = 13;    // OK
    }
    

    多继承下的构造函数

    #include<iostream>
    using namespace std;
    class B1
    {
    public:
        B1(int i)
        {
            cout<<"B1"<<endl;
        }
    };
    class B2
    {
    public:
        B2(int i)
        {
            cout<<"B2"<<endl;
        }
    };
    class B3
    {
    public:
        B3(int i)
        {
            cout<<"B3"<<endl;
        }
    };
    class B4
    {
    public:
        B4(int i)
        {
            cout<<"B4"<<endl;
        }
    };
    class D : public B2, virtual B1, public B4, virtual B3
    {
    public:
        D(int n): B1(n), B2(n), B3(n), B4(n) {}
    };
    int main( )
    {
        D d(1);
        return 0;
    }
    
    执行结果:
    
    B1
    B3
    B2
    B4
    

    在同一层次中,先调用虚基类的构造函数,接下来依次是非虚基类的构造函数,然后是派生类的构造函数。
    若同一层次中包含多个虚基类,这些虚基类的构造函数按对它们声明的先后次序调用;非虚基类也是按照它们的声明先后次序调用

    参考
    https://www.cnblogs.com/wkfvawl/p/10756539.html

  • 相关阅读:
    OGNL与值栈
    Struts2的数据封装
    Struts2页面配置和访问servlet API
    Struts2入门介绍(二)
    Struts2 入门介绍(一)
    Hibernate批量抓取
    Problem G: STL——整理唱片(list的使用)
    STL详细介绍(更新中~~~)
    Problem E: 数量的类模板
    CF: Long Number
  • 原文地址:https://www.cnblogs.com/hunter-w/p/13260417.html
Copyright © 2011-2022 走看看