脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - Python设计模式结构型组合模式

Python设计模式结构型组合模式

2022-09-28 13:25范桂飓 Python

这篇文章主要介绍了Python设计模式结构型组合模式,组合模式即Composite Pattern,将对象组合成成树形结构以表示“部分-整体”的层次结构,组合模式使得用户对单个对象和组合对象的使用具有一致性,下文具有一定的参考价值,需要

一、组合模式

组合,将多个对象组合成为一个树状结构,来表示业务逻辑上的层次。组合模式使得用户对单个对象和组合对象的使用具有一致性。

比如,描述一家公司的层次结构,那么我们用办公室来表示节点,则总经理办公司是根节点,下面分别由人事办公室、业务办公室、生产办公室、财务办公室,每个办公室下面可以还有跟小的办公室,每个办公室都有职责、人员数、人员薪资等属性;

优点:

  • 定义了包含基本对象和组合对象的类层次结构。
  • 简化 Client 代码,即 Client 可以一致地使用组合对象和单个对象。
  • 更容易增加新类型的组件。

二、应用场景

用于设计一个有层次等级的系统,并处理各层次之间的关系。

三、代码示例

Python设计模式结构型组合模式

实体角色:

  • 抽象组件(Component
  • 叶子组件(Leaf
  • 复合组件(Composite
  • 客户端(Client
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
class ComponentBase:
    """部门抽象出来的基类"""
    def __init__(self, name):
        slef.name = name
 
    def add(self, obj):
        pass
 
    def remove(self, obj):
        pass
 
    def display(self, number):
        pass
 
 
class Node(ComponentBase):
 
    def __init__(self, name, duty):
        self.name = name
        self.duty = duty
        self.children = []
 
    def add(self, obj):
        self.children.append(obj)
 
    def remove(self, obj):
        self.children.remove(obj)
 
    def display(self, number=1):
        print("部门:{} 级别:{} 职责:{}".format(self.name, number, self.duty))
        n = number+1
        for obj in self.children:
            obj.display(n)
 
 
if __name__ == '__main__':
    root = Node("总经理办公室", "总负责人")
    node1 = Node("财务部门", "公司财务管理")
    root.add(node1)
    node2 = Node("业务部门", "销售产品")
    root.add(node2)
    node3 = Node("生产部门", "生产产品")
    root.add(node3)
    node4 = Node("销售事业一部门", "A产品销售")
    node2.add(node4)
    node5 = Node("销售事业二部门", "B产品销售")
    node2.add(node5)
    root.display()

到此这篇关于Python设计模式结构型组合模式的文章就介绍到这了,更多相关Python组合模式内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://is-cloud.blog.csdn.net/article/details/122933725

延伸 · 阅读

精彩推荐