Python组合模式介绍、使用方法

一、Python组合模式介绍

概念: 组合模式(Composite Pattern)是一种结构型设计模式,它通过将对象组合成树状结构来表示“整体/部分”层次结构,让客户端可以以相同的方式处理单个对象和组合对象。

功能:

  1. 统一对待组合对象和叶子对象
  2. 方便添加/删除节点
  3. 简化客户端代码

优点:

  1. 可以更方便地添加/删除节点
  2. 简化客户端代码,不需要考虑是处理单个对象还是组合对象
  3. 可以灵活地组合对象和叶子对象来构建树状结构

缺点:

  1. 如果处理节点的行为不一致时会导致设计复杂度和实现难度增加
  2. 可能会对性能有一定影响,因为需要递归遍历整个树状结构

应用场景:

        适用于抽象物件组成树形结构的情况,例如:目录和文件、公司组织结构、菜单和菜单项等。

使用方式:

        组合模式通常需要定义一个抽象组件类,在组件类中定义了组合对象和叶子对象的公共行为。同时定义了组合对象和叶子对象的具体类,实现抽象组件类中的方法。组合对象中还需要定义一个列表,来存储子节点。

在应用程序中的应用: 例如在一个公司组织结构中,公司由多个部门组成,而部门又由员工和下属部门组成,可以使用组合模式来表示。可以使用一个抽象组件类来表示部门和员工,使用具体的组合对象和叶子对象表示实际的部门和员工。客户端可以通过调用抽象组件类中的方法来处理组合对象和叶子对象,使得客户端代码更加简洁。

二、组合模式使用

工作原理:

        组合模式中,抽象组件类定义了共有的接口,具体组合对象和叶子对象实现了这些接口。

组合对象包含一个子组件列表,可以对子组件进行操作。

客户端可以通过调用组合对象的方法来操作组件,包括添加、删除和检索子组件。

组合模式通过将对象组织成树型结构,使得客户端可以以相同的方式处理单个对象和组合对象。

示例:

假设我们要处理一个公司组织结构,公司由多个部门组成,而部门又由员工和下属部门组成。使用组合模式来表示该组织结构。

首先,定义一个抽象组件类,定义了组合对象和叶子对象的公共行为,这里我们定义为Component:

接着,定义具体组合对象,即Department类,定义为包含子节点的Component对象:

然后,定义叶子对象,即Employee类,该类没有子节点:

最后,客户端可以使用组合模式进行操作,例如创建公司组织结构:


from abc import ABC, abstractmethod# 定义抽象组件类
class Component():@abstractmethoddef show(self):pass# 定义具体组合对象, 包含子节点的Component对象
class Department(Component):def __init__(self, name):self._name = nameself._children = []def add(self, component):    # 添加组件self._children.append(component)def remove(self, component): # 删除组件self._children.remove(component)def show(self):# print("Department show")print(self._name)for child in self._children:child.show()        # 实现抽象方法,显示组件# 定义叶子节点,没有子节点
class Employee(Component):def __init__(self, name):self._name = namedef show(self):# print("Employee show")print(self._name)      # 显示组件# 使用组合模式,创建公司组织架构
dept1 = Department("研发部")
dept1.add(Employee("name1"))
dept1.add(Employee("name2"))
dept1.add(Employee("name0"))dept2 = Department("财务部")
dept2.add(Employee("name3"))
dept2.add(Employee("name4"))emp = Department("宇宙公司")
emp.add(dept1)
emp.add(dept2)emp.show()

输出结果为:

宇宙公司
研发部
name1
name2
name0
财务部
name3
name4

从输出结果可以看出,组合对象和叶子对象可以以相同的方式进行处理,客户端可以使用组合对象中的方法来添加、删除和显示组件,使得客户端代码更加简洁。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/7010.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32H5开发(1)----总览

STM32H5开发----1.总览 概述样品申请STM32H5-2MB 框图产品列表STM32H5-2MB 框图STM32H5-128KB框图功能对比STM32H5-128KB vs H5-2MB组员对比STM32H5 亮点 概述 STM32H5系列微控制器是意法半导体公司推出的一款高性能MCU, CortexM33内核的微控制器产品。 他和STM32F2、F4、F7、…

论文精度系列之详解图神经网络

论文地址:A Gentle Introduction to Graph Neural Networks 翻译:图表就在我们身边;现实世界的对象通常根据它们与其他事物的连接来定义。一组对象以及它们之间的连接自然地表示为图形。十多年来,研究人员已经开发了对图数据进行操作的神经网络(称为图神…

CentOS 7.9 安装 mydumper(RPM方式)

链接:https://pan.baidu.com/s/1sGhtiKPOmJw1xj0zv-djkA?pwdtaoz 码:taoz 开始正文啦: rpm -ivh mydumper-0.14.5-3-zstd.el7.x86_64.rpm 问题如下: 解决: yum -y install epel-release yum install -y libzstd …

python 小案例

要使用Django开发一个抽奖活动的后台,需要进行以下步骤: 安装Django:首先确保已经安装了Python和pip,然后使用pip安装Django库: pip install django 创建Django项目:在命令行中执行以下命令创建一个新的Dja…

zabbix安装Grafana

一、web访问 https://s3-us-west-2.amazonaws.com/grafana-releases/release/grafana-4.6.1-1.x86_64.rpm [rootserver ~] yum localinstall -y grafana-4.6.1-1.x86_64.rpm //yum方式安装本地rpm并自动解决依赖关系 [rootserver ~] grafana-cli plugins install alexanderzob…

elementUI 表格滚动分页加载请求数据

需求:elementui Table表格滚动分页(不使用分页组件),请求数据。 1、自定义加载更多数据的指令,在utils文件夹中创建 loadMore.js /*** 加载更多数据的指令*/ export default {install(Vue) {Vue.mixin({directives: …

利用 trait 实现多态

我在书上看到基于 std::io::Write 的示例,它是一个 trait 类型,内部声明了一些方法。和 go 语言不同,rust 中类型必须明确实现 trait 类型,而 go 语言属于 duck 模式。 std::io::Write下面的例子中调用 write_all 方式来演示&…

【SpringBoot】SpringBoot JPA 基础操作(CURD)

SpringData JPA 基本介绍 Spirng data jpa是spring提供的一套简化JPA开发的框架,按照约定好的【方法命名规则】写dao层接口,就可以在不写接口实现的情况下,实现对数据库的访问和操作。 同时提供了很多除了CRUD之外的功能,如分页…

国标GB28181视频监控平台EasyGBS无法播放,抓包返回ICMP的排查过程

国标GB28181视频平台EasyGBS是基于国标GB/T28181协议的行业内安防视频流媒体能力平台,可实现的视频功能包括:实时监控直播、录像、检索与回看、语音对讲、云存储、告警、平台级联等功能。国标GB28181视频监控平台部署简单、可拓展性强,支持将…

ZQC的游戏 题解

前言 这题题意描述不是很清楚啊,所以我找了个有权限的人把题面改了改,应该还是比较清楚了。 感觉这道题挺妙的,就来写一篇题解。 思路 首先,根据贪心思想,我们会将 1 1 1 号点半径以内能吃的都吃了,假…

【JavaScript】正则表达式常用元字符使用方法(实例)

目录 一、基本元字符1.\d2.\D3.\s4.\S5.\w6.\W7..8.\ 二、边界符1.^2.$3.用 ^ 和 $ 限制开头和结尾 三、限定符1.*2.3.?4.{n}5.{n,}6.{n,m} 四、特殊符号1.()2.|3.[] 五、exec()函数实例 一、基本元字符 1.\d //表示至少包含一位数字(0-9)var reg /\d/;console.lo…

1 请使用js、css、html技术实现以下页面,表格内容根据查询条件动态变化。

1.1 创建css文件,用于编辑style 注意: 1.背景颜色用ppt的取色器来获取: 先点击ppt的形状轮廓,然后点击取色器,吸颜色,然后再点击形状轮廓的其他轮廓颜色,即可获取到对应颜色。 2.表格间的灰色线…

【Spring Boot】Web开发 — 数据验证

Web开发 — 数据验证 对于应用系统而言,任何客户端传入的数据都不是绝对安全有效的,这就要求我们在服务端接收到数据时也对数据的有效性进行验证,以确保传入的数据安全正确。接下来介绍Spring Boot是如何实现数据验证的。 1.Hibernate Vali…

生态合作丨MemFireDB通过麒麟软件NeoCertify认证

近日,敏博科技“MemFireDB分布式关系数据库系统V2.8”与麒麟软件“银河麒麟高级服务器操作系统V10” 完成兼容性测试,获得麒麟软件 NeoCertify 认证证书。测试结果显示,MemFireDB数据库在国产操作系统上运行稳定,产品已经达到通用…

RocketMQ集成Springboot --Chapter4

RocketMQ实现延时消费 rocketMQTemplate.syncSend(“helloTopicBoot”,msg,3000,3); 3000为等待消息回传时间,如果3000毫秒还没有回传即发送错误信息, 3为延时消费的时间 /***生产者*发送延时消息*/Testpublic void sendDelayMsg(){Message msg Message…

Mysql-DQL查询

目录 1.DQL 基本语法 基本查询 条件查询 聚合函数 分组查询 排序查询 分页查询 1.DQL 数据查询语言,用来查询数据库中表的记录。 查询关键字:select 基本语法 SELECT 字段列表 FROM 表名列表 WHERE 条件列表 GROUP BY 分组字…

android studio(火烈鸟版本)使用protobuf

一、简介 Protobuf 全称:Protocol Buffers,是 Google 推出的一种与平台无关、语言无关、可扩展的轻便高效的序列化数据存储格式,类似于我们常用的 xml 和 json。 二、特点 Protobuf 用两个字总结:小,快。用 Protobu…

十大排序算法详解

目录 1. 冒泡排序 a. 思路 b. code 2. 插入排序 a. 思路 b. code 3. 希尔排序【插入排序plus】 a. 思路 b. code 4. 选择排序 a. 思路 b. code 5. 基数排序 a. 前置知识 b. 思路 c. code 6. 计数排序 a. 思路 b. code 7. 桶排序(计数排序plus &…

Could not resolve placeholder

本质原因:项目启动未扫描到该配置,一般来说是配置不对 检查方向 1、检查编译后的target包里是否有该配置所在的文件 如果不在就clear,重新编译启动再去检查 2、检查启动的环境是否匹配 编译后的target包下的配置文件名称是否跟启动类的环境…

【如何训练一个中译英翻译器】LSTM机器翻译模型部署之ncnn(python)(四)

ncnn:https://github.com/Tencent/ncnn 1、.h5模型保存为TFSaveModel格式 import tensorflow as tf from keras.models import load_model# 加载Keras模型 model load_model(encoder_model.h5)# 转换为SavedModel类型 tf.saved_model.save(model, TFSaveModel)2、…