组合模式(Composite)

组合模式:一种数据的组织形式,要解决的问题与迭代器模式(Iterator)类似都是聚合对象的遍历和处理,但是组合模式处理的问题比迭代器模式(Iterator)更加复杂

  1. 组合模式原理:
  • 餐厅菜单新需求导致的遍历困难

    • 餐厅菜单聚类结构现状(不关心怎么实现、数据结构,只要获取到迭代器就可以访问菜单明细,很好的解耦了)

      组合模式(Composite)_第1张图片
      Paste_Image.png
    • 添加餐后甜点子菜单

      组合模式(Composite)_第2张图片
      Paste_Image.png

      困难:数据结构?怎么遍历?
      数据结构中的子项必须是MenuItem类型的(扩展的不是),导致遍历也出现问题

    • 结构抽象

    组合模式(Composite)_第3张图片
    Paste_Image.png
    1. 需要用树形结构,节点是菜单或子菜单,叶子是菜单项,
    2. 需要能够在各个菜单项之间游走,遍历
    3. 要能够有弹性的在菜单项之间游走(可能只遍历部分子菜单)
  • 组合模式的原理和设计方案
    组合模式:将对象组合成树形结构以表示“部分-整体”的层次结构,组合模式能让用户以一致的方式(继承自同一个超类)来处理单个对象(菜单)及组合对象(子菜单),也就是我们可以忽略单个对象与组合对象之间的差别(继承自同一个超类)

    组合模式(Composite)_第4张图片
    Paste_Image.png
  1. 组合模式示例代码讲解
  • 示例项目类结构图

    组合模式(Composite)_第5张图片
    Paste_Image.png
  1. 组合模式关键点

你可能感兴趣的:(组合模式(Composite))