C++ 学习笔记(20)钻石继承与虚基类

防止二义性,所以加限定。

#include<iostream>
using namespace std;

class B1{
public:
	B1():n(0){
	}
public:
	int n;
};
	
class B2{
public:
	B2():n(0){
	}
public:
	int n;
};

class D : public B1,public B2{
public:
	D():x(0){
	}
private:
	int x;
};

void main(){
	D d;
	//d.n = 10;  //这里有二义性
	d.B1::n = 10;
}

钻石继承

#include<iostream>
using namespace std;

//钻石继承
class B0{
public:
	B0():m(0){
	}
public:
	int m;
};

class B1 : public B0{
public:
	B1():n(0){
	}
public:
	int n;
};
	
class B2 : public B0{
public:
	B2():n(0){
	}
public:
	int n;
};

class D : public B1,public B2{
public:
	D():x(0){
	}
private:
	int x;
};

void main(){
	D d;
	//d.n = 10;  //这里有二义性
	d.B1::n = 10;
	d.B2::n = 20;
	//d.m = 100;  //这里有二义性
	//但是实际上m是只有一个,所以这个方法不符合实际
	d.B1::m = 100;
	d.B2::m = 200;
}

虚拟继承

virtual可以再public前面,也能在public后面。

#include<iostream>
using namespace std;

//钻石继承
//虚拟继承
//虚基类

class B0{
public:
	B0():m(0){
	}
public:
	int m;
};

class B1 : virtual public B0{
public:
	B1():n(0){
	}
public:
	int n;
};
	
class B2 : virtual public B0{
public:
	B2():n(0){
	}
public:
	int n;
};

class D : public B1,public B2{
public:
	D():x(0){
	}
private:
	int x;
};

void main(){
	D d;
	//d.n = 10;  //这里有二义性
	d.B1::n = 10;
	d.B2::n = 20;

	//d.m = 100;  //这里有二义性
	/*
	//但是实际上m是只有一个,所以这个方法不符合实际
	d.B1::m = 100;
	d.B2::m = 200;
	*/
	d.m = 100;		
}

虚基类

#include<iostream>
using namespace std;

//钻石继承
//虚拟继承
//虚基类

class B0{
public:
	B0():m(0){
	}
public:
	int m;
};

class B1 : virtual public B0{
public:
	B1():n(0){
	}
public:
	int n;
};
	
class B2 : virtual public B0{
public:
	B2():n(0){
	}
public:
	int n;
};

class Base1{
public:
	Base1(int x = 0):m_x(x){  //参数列表的初始化进行初始化
		cout<<"Create Base1!"<<endl;
	}
	~Base1(){
		cout<<"Free Base1!"<<endl;
	}
private:
	int m_x;
};
	
class Base2{
public:
	Base2(int y = 0):m_y(y){
		cout<<"Create Base2!"<<endl;
	}
	~Base2(){
		cout<<"Free Base2!"<<endl;
	}
private:
	int m_y;
};

class Base3{
public:
	Base3(int z = 0):m_z(z){
		cout<<"Create Base3!"<<endl;
	}
	~Base3(){
		cout<<"Free Base3!"<<endl;
	}
private:
	int m_z;
};

class D : public Base2,virtual public Base1,public Base3{  //父类的构造顺序按照这里的顺序
public:
	D(int data)//:Base1(data),Base2(data),Base3(data),b1(data),b2(data),b3(data)
	{
		cout<<"Create D!"<<endl;
	}
	~D(){
		cout<<"Free D!"<<endl;
	}
private:  //按照顺序构造
	Base3 b3;
	Base1 b1;
	Base2 b2;
};

void main(){
	D d(10);
}

顺序:先构造虚基类,然后构造非虚基类,再构造成员对象,最后构造派生类。

 

版权声明:本文为博主原创文章,如有错误,恳请大家在评论区指出,在下不胜感激~如要转载注明出处即可~

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 13:35
虽然不怎么光彩,经过这件事,可能我真的要去认同“面试八股文早该淘汰!不会用AI作弊的程序员=新时代文盲!”这句话了
HellowordX:Ai的出现是解放劳动力的,不是用来破坏公平竞争环境的,这样下去,轻则取消所有线上面试,严重了会影响整个行业对所有人产生影响,企业会拉高入职考核各种离谱考核会层出不穷
你找工作的时候用AI吗?
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-07 14:00
不想多说了,什么逆天HR,还要教我礼貌😂
机械打工仔:这不纯傻卵吗,他还操心上别人老板了
投递BOSS直聘等公司7个岗位
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务