当前位置: 首页 > news >正文

菱形继承 虚继承

菱形继承 虚继承

在c++中,在使用多继承时如果发生类A排石出类B和类C,类D继承自类B和类C,这是就发生菱形继承。

在这里插入图片描述

如果这时D调用A那编译器就发生了混乱,它不知道要用B中的A还是C中的A。

验证代码如下

//菱形继承
class A {protected:int m_a;
};
//直接基类B
class B : public A {protected:int m_B;
};
class C : public A {protected:int m_C;
};
class D : public B,public C {
public:void srtA(int A) {//错误的方式 m_a=A;//正确的方式——需要进行声明或者使用虚继承B::m_a=A;}void setB(int B) {m_B = B;}void setc(int c) {m_C = c;}void setD(int D) {m_D = D;}
private:
int m_D;
};

很好虽然用进行声明的方式可以解决,但是又会出现另一个问题,就是数据冗余,为了解决菱形继承出现的数据冗余的问题C++提出了虚继承,虚继承使得派生类中只保留一份间接成员

需要用到 virtual

语法

class B:virtual public A{};

我们把之前的代码改一改发现果然解决了问题


//菱形继承
class A {protected:int m_a;
};
//直接基类B
class B : virtual public A {protected:int m_B;
};//这里改了
class C : virtual public A {protected:int m_C;
};//这里改了
class D : public B,public C {
public:void srtA(int A) {m_a=A;}void setB(int B) {m_B = B;}void setc(int c) {m_C = c;}void setD(int D) {m_D = D;}
private:
int m_D;
};
int main() {D d;return 0;
}

虚继承构造函数

在序继承中,虚基类是由最终的派生类初始化的。

简单点说就是由最后一次子类初始化他才会改变。


#include <iostream>
#include <bits/ostream.tcc>
using namespace std;
//菱形继承
class A {protected:int m_a;
public:A(int a):m_a(a){}void print() {cout<<this->m_a<<endl;}
};
//直接基类B
class B : virtual public A {protected:int m_B;public:B(int a,int b):A(a),m_B(b){}void print() {cout<<this->m_a<<" "<<this->m_B<<endl;}
};
class C : virtual public A {protected:int m_C;
public:C(int a,int c):A(a),m_C(c){}void print() {cout<<this->m_a<<" "<<this->m_C<<endl;}
};
class D : public B,public C {
public:D(int a,int b,int c,int d):
A(a),B(90,b),C(100,c),m_D(d){}
//在这里虽然赋过90和100 但是这里赋值不作数void srtA(int A) {m_a=A;}void setB(int B) {m_B = B;}void setc(int c) {m_C = c;}void setD(int D) {m_D = D;}void print() {cout<<this->m_a<<" "<<this->m_B<<" "<<this->m_C<<" "<<this->m_D<<endl;}private:
int m_D;};
int main() {A a1(111);a1.print();B b1(222 ,333);b1.print();C c1(444 ,555);c1.print();D d1(666,777,888,999);d1.print();return 0;
}

这篇博客到这里就结束了喜欢记得点赞哦(๑′ᴗ‵๑)I Lᵒᵛᵉᵧₒᵤ❤

http://www.lryc.cn/news/592817.html

相关文章:

  • Java学习------ConcurrentHashMap
  • 外部DLL创建及使用
  • react控制react Popover组件显示隐藏
  • Agent AI(3):Agent分类
  • Jenkins pipeline 部署docker通用模板
  • 网关-微服务网关入门
  • 《Qt数据库》知识点实践
  • VisualXML全新升级 | 新增BusLoad计算
  • 在 OpenSUSE Tumbleweed 和 Leap 上安装 VirtualBox
  • ChatGPT Agent:统一端到端Agentic模型的技术革新与行业影响
  • Sui 在非洲增长最快的科技市场开设 SuiHub Lagos 以推动创新
  • 质变科技亮相可信数据库发展大会,参编《数据库发展研究报告2025》
  • 读书笔记:《动手做AI Agent》
  • 飞算科技:以创新科技引领数字化变革,旗下飞算 JavaAI 成开发利器
  • 软件工程中的《资本论》
  • KRaft 角色状态设计模式:从状态理解 Raft
  • Redis学习其二(事务,SpringBoot整合,持久化RDB和AOF)
  • java基础——面向对象04(继承)
  • 通俗易懂:什么是决策树?
  • STM32-第七节-TIM定时器-3(输入捕获)
  • STL—— list迭代器封装的底层讲解
  • 小白学Python,网络爬虫篇(2)——selenium库
  • 2025年Flutter开发主流技术栈
  • Windows发现可疑的svchost程序
  • 怎么自己搭建云手机
  • Hive 向量化执行引擎 Vectorized Execution 常见 NPE 报错分析及解决
  • 域名WHOIS信息查询免费API使用指南
  • HIVE实战处理(二十四)留存用户数
  • 专题:2025智能体研究报告|附70份报告PDF、原数据表汇总下载
  • 线程控制:互斥与同步