美文网首页
设计模式(python实现)--组合模式(Composite)

设计模式(python实现)--组合模式(Composite)

作者: 远行_2a22 | 来源:发表于2020-02-02 14:54 被阅读0次

Composite

动机(Motivation)

  • 客户代码过多地依赖于对象容器复杂的内部实现结构,对象容器内部实现结构(而非抽象结构)的变化
    引起客户代码的频繁变化,带来了代码的维护性、扩展性等弊端。
  • 如何将”客户代码与复杂的对象容器结构“解耦?让对象容器自己来实现自身的复杂结构,从而使得客户代码就像处理简单对象一样来处理复杂的对象容器?

模式定义

将对象组合成树形结构以表示”部分-整体“的层次结构。Composite使得用户对单个对象和组合对象的使用具有一致性(稳定)。
——《设计模式》GoF

要点总结

  • Composite模式采用 树性结构 来实现普遍存在的对象容器,从而将一对多的关系转化为一对一的关系,使得客户代码可以一致地(复用)处理对象和对象容器,
    无需关心处理的是单个的对象,还是组合的对象容器。
  • 客户代码与纯粹的抽象接口——而非对象容器的内部实现结构——发生依赖,从而更能”应对变化“。
  • Composite模式在具体实现中,可以让父对象中的子对象反向追溯;如果父对象有频繁的遍历需求,可使用缓存技术来改善效率。

例子

# -*- coding:utf-8 -*-


class Component(object):
    def __init__(self, node_name):
        self.node_name = node_name

    def process(self):
        pass


class TreeNode(Component):

    def __init__(self, node_name):
        super(TreeNode, self).__init__(node_name)
        self.node_list = []

    def process(self):
        self._process_cur_node()
        self._process_sub_node()

    def add_node(self, node):
        self.node_list.append(node)

    def remove_node(self, node):
        self.node_list.pop(node)

    def _process_cur_node(self):
        print('process cur node:', self.node_name)

    def _process_sub_node(self):
        for sub_node in self.node_list:
            sub_node.process()


class LeafNode(Component):

    def process(self):
        print('process leaf node:', self.node_name)


if __name__ == '__main__':
    root_node = TreeNode('root')
    tree_node1 = TreeNode('tree_node1')
    tree_node2 = TreeNode('tree_node2')
    tree_node3 = TreeNode('tree_node3')
    leaf_node1 = LeafNode('leaf_node1')
    leaf_node2 = LeafNode('leaf_node2')

    root_node.add_node(tree_node1)
    root_node.add_node(tree_node2)
    tree_node1.add_node(tree_node3)
    tree_node3.add_node(leaf_node1)
    tree_node3.add_node(leaf_node2)

    root_node.process()

输出

('process cur node:', 'root')
('process cur node:', 'tree_node1')
('process cur node:', 'tree_node3')
('process leaf node:', 'leaf_node1')
('process leaf node:', 'leaf_node2')
('process cur node:', 'tree_node2')

相关文章

网友评论

      本文标题:设计模式(python实现)--组合模式(Composite)

      本文链接:https://www.haomeiwen.com/subject/zgkqxhtx.html