博客
关于我
40. Use multiple inheritance judiciously
阅读量:729 次
发布时间:2019-03-21

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

多重继承作为面向对象编程中的一个工具,在实际开发中经常被讨论和使用。但在设计中必须格外谨慎地使用它与单一继承相比,多重继承往往显得更加复杂且难以理解。因此在有面积很大的单一继承方案时,往往可以转而采用其等效的低复杂度实现方案。当然,多重继承也并非完全没有其存在的价值。在一些特定场景下,它确实能以最简洁的方式实现事物的表达。

需要注意的一个关键点是多重继承可能引入额外的歧义性,这种情况下的类成员关系会变得更加复杂。这也意味着在设计基础类时,如果引入了虚拟继承(virtual inheritance),都会对代码的大小、速度和初始化效率产生显著影响。因此只有当核心base类完全不含数据(如纯抽象类或接口)的情况下,使用虚拟继承才是更好的选择。

有人或许会质疑,多重继承是否还有真正的必要。在我看来,答案是肯定的。例如,在某些用例中,可能需要以公共方式继承一个接口,同时以私有方式继承另一个辅助实现类。这是一种在多重继承体系中展现出独特优势的情况。这种设计通常只有多重继承才能做到。

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

你可能感兴趣的文章
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
mysql 协议的退出命令包及解析
查看>>