组合模式:一种数据的组织形式,要解决的问题与迭代器模式(Iterator)类似都是聚合对象的遍历和处理,但是组合模式处理的问题比迭代器模式(Iterator)更加复杂
组合模式原理:
餐厅菜单新需求导致的遍历困难
餐厅菜单聚类结构现状(不关心怎么实现、数据结构,只要获取到迭代器就可以访问菜单明细,很好的解耦了)
添加餐后甜点子菜单
困难:数据结构?怎么遍历?
数据结构中的子项必须是MenuItem类型的(扩展的不是),导致遍历也出现问题结构抽象
- 需要用树形结构,节点是菜单或子菜单,叶子是菜单项,
- 需要能够在各个菜单项之间游走,遍历
- 要能够有弹性的在菜单项之间游走(可能只遍历部分子菜单)
组合模式的原理和设计方案
组合模式:将对象组合成树形结构以表示“部分-整体”的层次结构,组合模式能让用户以一致的方式(继承自同一个超类)来处理单个对象(菜单)及组合对象(子菜单),也就是我们可以忽略单个对象与组合对象之间的差别(继承自同一个超类)
组合模式示例代码讲解
示例项目类结构图
组合模式关键点