组合模式(Composite)

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

  1. 组合模式原理:

    • 餐厅菜单新需求导致的遍历困难

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

        组合模式(Composite)
        Paste_Image.png
      • 添加餐后甜点子菜单

        组合模式(Composite)
        Paste_Image.png

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

      • 结构抽象

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

      组合模式(Composite)
      Paste_Image.png
  2. 组合模式示例代码讲解

    • 示例项目类结构图

      组合模式(Composite)
      Paste_Image.png
  3. 组合模式关键点

上一篇:发展中的物联网与智慧城市


下一篇:强制删除windows拒绝访问的文件夹