多用组合少用继承的设计思想

本文通过具体例子解释了为何在软件设计中多用组合而非继承的原因。继承可能导致层次过深及复杂度过高,影响代码的可读性和可维护性。文章探讨了如何通过组合简化设计,并以桥接模式为例进行了说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为什么多用组合少用继承?继承最大的问题就在于:容易继承层次过深、继承关系过于复杂影响到代码的可读性和可维护性。

为什么继承容易过深过复杂?继承是实现多态的手段,当态太多时,就容易导致过于复杂和过深。

我们以穿戴衣物为例,如图:

从对人体保护部位的不同可以分为:

 

从品牌不同可分为:

为了图更简单,我略掉了袜子、帽子、手套。

从季节不同可分为:

从材质不同分为:

到目前为此你可能觉得都简单,现在如果通过继承要把这些不同都表现在衣物上会变成什么?会是一个多层的多叉树,想想都觉得很乱是不是?

如果通过继承把这些不同维度特性表现在衣物上,则必然导致继承类过多,扩展性差,维护困难,这种现象可称为继承爆炸。

如果换成组合会怎么样呢?以品牌为例,我们来看怎么表现在衣物上,其他如季节、材质跟品牌一样。

通过组合方式很简单的就把一个多层多叉树,变成了只有二层继承的结构。

多用组合少用继承思想在设计模式中有很多的运用。我自己在学习设计模式的过程,就对桥接模式有很多的疑惑,直到理解了多用组合少用继承设计思想,才直正理解桥接模式。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值