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

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

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

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

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

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

你可能感兴趣的文章
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>
Mysql DBA 高级运维学习之路-DQL语句之select知识讲解
查看>>
mysql deadlock found when trying to get lock暴力解决
查看>>
MuseTalk如何生成高质量视频(使用技巧)
查看>>
mutiplemap 总结
查看>>
MySQL DELETE 表别名问题
查看>>
MySQL Error Handling in Stored Procedures---转载
查看>>