博客
关于我
C++面向对象(十一)多继承
阅读量:124 次
发布时间:2019-02-27

本文共 384 字,大约阅读时间需要 1 分钟。

关于C++中的虚基类和多继承导致的内存浪费问题,可以通过以下方法进行优化:

  • 虚继承的应用:确保所有直接继承自A的派生类(如B和C)使用虚继承。这样,派生类只保留一个基类A的拷贝,而不是各自有独立的拷贝。例如,定义B和C时使用class B : virtual public Aclass C : virtual public A

  • 构造函数的初始化列表:在派生类D的构造函数中,明确调用A、B和C的构造,以确保正确的构造顺序和内存布局。例如,D的构造函数应包含A(data), B(data), C(data)。这样,A会被构造为共享拷贝,而B和C则各自拥有独立的空间。

  • 构造顺序:确保构造顺序是A → B → C → D。这样,虚基类A会被先构造,然后是B和C,最后是D。这样,内存会被合理分配,避免浪费。

  • 通过以上方法,内存浪费问题得到有效解决,优化了内存使用。

    转载地址:http://jmyd.baihongyu.com/

    你可能感兴趣的文章
    oracle tirger_在Oracle中,临时表和全局临时表有什么区别?
    查看>>
    Oracle Validated Configurations 安装使用 说明
    查看>>
    oracle where 条件的执行顺序分析1
    查看>>
    oracle 中的 CONCAT,substring ,MINUS 用法
    查看>>
    Oracle 中的 decode
    查看>>
    oracle 中表一对多取多方的最新的一条数据
    查看>>
    oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
    查看>>
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 修改数据库表数据提交之后进行回滚
    查看>>
    UML-总结
    查看>>
    oracle 内存参数示意图
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>
    UML- 配置图(部署图)
    查看>>
    oracle 切割字符串加引号_使用Clean() 去掉由函数自动生成的字符串中的双引号...
    查看>>
    Oracle 创建 DBLink 的方法
    查看>>
    oracle 创建job
    查看>>
    oracle 创建一个用户,只能访问指定的对象
    查看>>
    oracle 创建双向备份,Materialized View 物化视图实现 Oracle 表双向同步
    查看>>
    oracle 创建字段自增长——两种实现方式汇总
    查看>>