博客
关于我
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下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    Oracle中序列的操作以及使用前对序列的初始化
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
    查看>>
    Oracle中的rownum 和rowid的用法和区别
    查看>>
    oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
    查看>>
    oracle中表和视图的区别,oracle中常用表和视图
    查看>>
    oracle之表空间(tablespace)、方案(schema)、段(segment)、区(extent)、块(block)
    查看>>
    Oracle从11g导出后导入10g
    查看>>
    oracle从备份归档日志的方法集中回收
    查看>>
    oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
    查看>>
    Oracle修改字段类型
    查看>>
    Oracle修改表或者字段的注释
    查看>>