news 2026/6/10 0:25:06

Python 中的组合模式(Composite Pattern)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python 中的组合模式(Composite Pattern)

Python 中的组合模式(Composite Pattern)

组合模式是一种结构型设计模式,其核心目的是:
将对象组合成树形结构以表示“部分-整体”的层次结构,使得客户端对单个对象和组合对象的使用具有一致性

形象比喻:就像文件系统——文件夹(容器)可以包含文件(叶子)和子文件夹,而文件夹又可以嵌套文件夹。客户端可以统一对待文件和文件夹(例如统一遍历、计算大小)。

组合模式的优点
  • 定义了包含基本对象和组合对象的类层次结构
  • 简化客户端代码:客户端可以一致处理单个对象和组合对象
  • 更容易添加新类型的组件
  • 符合“开闭原则”:对扩展开放(新增组件类型)
典型应用场景
  • 文件系统(文件 + 目录)
  • GUI 组件树(窗口、面板、按钮、标签等)
  • 组织架构(公司、部门、员工)
  • 图形绘制(基本图形 + 图形组)
  • XML / HTML DOM 树
  • 菜单系统(菜单项 + 子菜单)
Python 实现示例:文件系统
fromabcimportABC,abstractmethodfromtypingimportList# 组件接口(Component)classFileSystemComponent(ABC):@abstractmethoddefget_name(self)->str:pass@abstractmethoddefget_size(self)->int:pass@abstractmethoddefdisplay(self,indent:str=""):pass# 叶子节点(Leaf):文件classFile(FileSystemComponent):def__init__(self,name:str,size:int):self.name=name self.size=sizedefget_name(self)->str:returnself.namedefget_size(self)->int:returnself.sizedefdisplay(self,indent:str=""):print(f"{indent}📄{self.name}({self.size}KB)")# 组合节点(Composite):目录classDirectory(FileSystemComponent):def__init__(self,name:str):self.name=name self.children:List[FileSystemComponent]=[]defget_name(self)->str:returnself.namedefadd(self,component:FileSystemComponent):self.children.append(component)defremove(self,component:FileSystemComponent):self.children.remove(component)defget_size(self)->int:# 递归计算总大小returnsum(child.get_size()forchildinself.children)defdisplay(self,indent:str=""):print(f"{indent}📁{self.name}({self.get_size()}KB)")forchildinself.children:child.display(indent+" ")# 客户端使用(统一对待文件和目录)if__name__=="__main__":# 创建文件file1=File("document.pdf",1024)file2=File("photo.jpg",2048)file3=File("script.py",256)# 创建目录src_dir=Directory("src")src_dir.add(File("main.py",512))src_dir.add(File("utils.py",128))docs_dir=Directory("docs")docs_dir.add(file1)docs_dir.add(file2)# 根目录root=Directory("MyProject")root.add(src_dir)root.add(docs_dir)root.add(file3)# 统一显示整个结构root.display()print("\n总大小:",root.get_size(),"KB")

输出

📁 MyProject (6016 KB) 📁 src (640 KB) 📄 main.py (512 KB) 📄 utils.py (128 KB) 📁 docs (3072 KB) 📄 document.pdf (1024 KB) 📄 photo.jpg (2048 KB) 📄 script.py (256 KB) 总大小: 6016 KB

客户端代码完全不需要区分是文件还是目录,都调用相同的display()get_size()方法。

更实用的例子:GUI 组件树
classGraphic(ABC):@abstractmethoddefdraw(self):passclassDot(Graphic):def__init__(self,x,y):self.x,self.y=x,ydefdraw(self):print(f"绘制点 ({self.x},{self.y})")classCircle(Graphic):def__init__(self,x,y,radius):self.x,self.y,self.radius=x,y,radiusdefdraw(self):print(f"绘制圆 中心({self.x},{self.y}) 半径{self.radius}")classCompoundGraphic(Graphic):def__init__(self):self.children:List[Graphic]=[]defadd(self,child:Graphic):self.children.append(child)defremove(self,child:Graphic):self.children.remove(child)defdraw(self):print("绘制复合图形 {")forchildinself.children:child.draw()print("}")# 使用compound=CompoundGraphic()compound.add(Dot(10,20))compound.add(Circle(50,50,30))big_compound=CompoundGraphic()big_compound.add(compound)big_compound.add(Dot(100,100))big_compound.draw()
组合模式结构总结
角色说明
Component抽象组件(FileSystemComponent / Graphic)
Leaf叶子节点(File / Dot / Circle)
Composite组合节点(Directory / CompoundGraphic)
Client统一操作 Component 的客户端
组合模式 vs 其他模式对比
模式目的结构特点
组合部分-整体层次结构,一致处理树形结构
装饰器动态添加职责链式包装
享元共享大量细粒度对象共享叶子节点
访问者在组合结构上添加新操作双分派
Python 中的实用建议
  • Python 的动态特性让组合模式实现非常自然。
  • 常与迭代器模式结合使用(遍历树结构)。
  • 在实际项目中非常常见:
    • lxmlxml.etree.ElementTree的 XML 树
    • PyQt/Tkinter的控件树
    • 游戏引擎中的场景图(Scene Graph)
    • AST(抽象语法树)在编译器中
  • 注意安全问题:如果叶子节点实现了某些组合节点没有的方法,客户端需小心(可用NotImplementedError)。
注意事项
  • 组合模式会产生很多小对象(尤其是叶子多时),注意性能。
  • 如果树很深,递归操作可能导致栈溢出(可用迭代方式替代)。
  • 叶子和组合的接口要保持一致(至少在客户端关心的操作上)。

组合模式是处理树形结构最优雅的方式之一,尤其在需要递归处理层次结构时。

如果你想看更高级的例子(如带删除、搜索功能的菜单系统、组织架构权限控制、结合访问者模式的图形编辑器),欢迎继续问!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 1:50:16

揭秘Wan2.2-TI2V-5B:突破性混合专家架构让视频创作触手可及

揭秘Wan2.2-TI2V-5B:突破性混合专家架构让视频创作触手可及 【免费下载链接】Wan2.2-TI2V-5B Wan2.2-TI2V-5B是一款开源的先进视频生成模型,基于创新的混合专家架构(MoE)设计,显著提升了视频生成的质量与效率。该模型支…

作者头像 李华
网站建设 2026/6/10 13:37:25

【mac部署Open-AutoGLM终极指南】:手把手教你从零搭建高效AI开发环境

第一章:mac部署Open-AutoGLM终极指南概述在 macOS 系统上部署 Open-AutoGLM 是构建本地大模型自动化推理环境的关键一步。该框架结合了 AutoGLM 的智能推理能力与开源灵活性,适用于自然语言处理、自动化脚本生成和本地化 AI 服务部署等多种场景。通过本指…

作者头像 李华
网站建设 2026/6/10 13:00:43

IDM激活终极指南:2025完整解决方案与实用技巧

还在为IDM的"序列号验证"弹窗而烦恼吗?想要永久解决IDM使用问题,享受稳定的下载体验?这份2025年最新版IDM使用指南将为你提供最简单有效的解决方案,从原理到实操,一步步带你彻底告别使用困扰。 【免费下载链…

作者头像 李华
网站建设 2026/5/25 20:04:58

终极免费AI论文工具:9款实测,查重率精准控制无压力!

一、前言:为什么这篇测评是你论文写作的“最后一站”? 作为常年和论文打交道的科研人,你是否经历过这些崩溃瞬间: 对着空白文档发呆3小时,连摘要都写不出一句?查重率飙到30%,改到凌晨两点还是…

作者头像 李华
网站建设 2026/6/7 17:02:20

Open-AutoGLM能否替代鼠标键盘?深度剖析其GUI自动化潜力

第一章:Open-AutoGLM可以操作电脑桌面吗Open-AutoGLM 是一个基于大语言模型的自动化工具框架,专注于自然语言驱动的任务执行。虽然其核心能力集中在文本理解与生成,但通过扩展集成,它具备间接操作电脑桌面的潜力。支持的桌面交互方…

作者头像 李华
网站建设 2026/5/30 8:09:08

终极Gmail账号自动生成工具:快速创建无限邮箱的完整教程

终极Gmail账号自动生成工具:快速创建无限邮箱的完整教程 【免费下载链接】gmail-generator ✉️ Python script that generates a new Gmail account with random credentials 项目地址: https://gitcode.com/gh_mirrors/gm/gmail-generator 在当今数字化时代…

作者头像 李华