当前位置: 首页 > news >正文

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

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

相关文章:

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

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

生成模型和判别模型工作原理介绍

您解决的大多数机器学习和深度学习问题都是从生成模型和判别模型中概念化的。在机器学习中,人们可以清楚地区分两种建模类型: 将图像分类为狗或猫属于判别性建模生成逼真的狗或猫图像是一个生成建模问题神经网络被采用得越多,生成域和判别域就增长得越多。要理解基于这些模型…...

shardingsphere读写分离配置

注: 如果是升级之前的单库单表,要将之前的 数据库接池 druid-spring-boot-starter 注释掉,换成 druid,否则无法连接数据库。 原因: 因为数据连接池的starter(比如druid)可能会先加载并且其创…...

登录报错 “msg“:“Request method ‘GET‘ not supported“,“code“:500

1. 登录失败 2. 排查原因, 把 PostMapping请求注释掉, 或改成GetMapping请求就不会报错 3. 找到SecurityConfig.java , 新增 .antMatchers("/**/**").permitAll() //匹配允许所有路径 4. 登录成功...

Python 日期和时间

Python 日期和时间 Python 程序能用很多方式处理日期和时间,转换日期格式是一个常见的功能。 Python 提供了一个 time 和 calendar 模块可以用于格式化日期和时间。 时间间隔是以秒为单位的浮点小数。 每个时间戳都以自从1970年1月1日午夜(历元&…...

pytorch的发展历史,与其他框架的联系

我一直是这样以为的:pytorch的底层实现是c(这一点没有问题,见下边的pytorch结构图),然后这个部分顺理成章的被命名为torch,并提供c接口,我们在python中常用的是带有python接口的,所以被称为pytorch。昨天无意中看到Torch是由lua语言写的&…...

Kibana-elastic--Elastic Stack--ELK Stack

Kibana 是什么? | Elastic 将数据转变为结果、响应和解决方案 使用 Kibana 针对大规模数据快速运行数据分析,以实现可观测性、安全和搜索。对来自任何来源的任何数据进行全面透彻的分析,从威胁情报到搜索分析,从日志到应用程序监测…...

Docker复杂命令便捷操作

启动所有状态为Created的容器 要启动所有状态为"created"的Docker容器,可以使用以下命令: docker container start $(docker container ls -aq --filter "statuscreated")上述命令执行了以下步骤: docker container l…...

Python中的datetime模块

time模块用于取得UNIX纪元时间戳,并加以处理。但是,如果以方便的格式显示日期,或对日期进行算数运算,就应该使用datetime模块。 目录 1. datetime数据类型 1) datetime.datetime.now()表示特定时刻 2)da…...

Flutter - 微信朋友圈、十字滑动效果(微博/抖音个人中心效果)

demo 地址: https://github.com/iotjin/jh_flutter_demo 代码不定时更新,请前往github查看最新代码 前言 一般APP都有类似微博/抖音个人中心的效果,支持上下拉刷新,并且顶部有个图片可以下拉放大,图片底部是几个tab,可…...

MySQL检索数据和排序数据

目录 一、select语句 1.检索单个列(SELECT 列名 FROM 表名;) 2.检索多个列(SELECT 列名1,列名2,列名3 FROM 表名;) 3.检索所有的列(SELECT * FROM 表名;) 4.检索不同的行&#x…...

通过STM32内部ADC将烟雾传感器发送的信号值显示在OLED上

一.CubeMX配置 首先我们在CubeMX配置ADC1, 设置一个定时器TIM2定时1s采样一次以及刷新一次OLED, 打开IIC用于驱动OLED显示屏。 二.程序 在Keil5中添加好oled的显示库,以及用来显示的函数、初始化函数、清屏函数等。在主程序中初始化oled,并将其清屏。…...

ZEPHYR 快速开发指南

简介 国内小伙伴在学习zephyr的时候,有以下几个痛点: 学习门槛过高github访问不畅,下载起来比较费劲。 这篇文章将我自己踩的坑介绍一下,顺便给大家优化一些地方,避免掉所有的坑。 首先用virtualbox 来安装一个ubu…...

【FPGA + 串口】功能完备的串口测试模块,三种模式:自发自收、交叉收发、内源

【FPGA 串口】功能完备的串口测试模块,三种模式:自发自收、交叉收发、内源 VIO 控制单元 wire [1:0] mode;vio_uart UART_VIO (.clk(ad9361_l_clk), // input wire clk.probe_out0(mode) // output wire [1 : 0] probe_out0 );将 mod…...

初步了解预训练语言模型BERT

本文字数::4024字 预计阅读时间:12分钟 BERT是由Google提出的预训练语言模型,它基于transformer架构,被广泛应用于自然语言处理领域,是当前自然语言处理领域最流行的预训练模型之一。而了解BERT需要先了解注…...

Android Hook系统 Handler 消息实现

前言 主线程的Handler 主要依赖于 ActivityThread,Android是消息驱动,比如view的刷新,activity的创建等,如果能打印系统层Handler消息日志,就需要对于系统层的Handler 进行Hook 原理 ActivityThread中 mH对象主要负责…...

R语言从入门到精通之【R语言的使用】

系列文章目录 1.R语言从入门到精通之【R语言介绍】 2.R语言从入门到精通之【R语言下载与安装】 3.R语言从入门到精通之【R语言的使用】 文章目录 系列文章目录一、新手上路1.R语句构成2.获取帮助3.工作空间二、包1.包的安装2.实践应用总结一、新手上路 1.R语句构成 R语句由函…...

WPF实战学习笔记29-登录数据绑定,编写登录服务

添加登录绑定字段、命令、方法 修改对象:Mytodo.ViewModels.ViewModels using Mytodo.Service; using Prism.Commands; using Prism.Events; using Prism.Mvvm; using Prism.Services.Dialogs; using System; using System.CodeDom.Compiler; using System.Collec…...

c++函数式编程:统计文件字符串,文件流

头文件 #include <iostream> #include <fstream> #include <string> #include <sstream> #include <algorithm> #include <vector>统计方法 int count_lines(const std::string &filename) {std::ifstream in{filename};return std:…...

scp命令----跨服务器传输文件

scp命令 Linux scp 命令用于 Linux 之间复制文件和目录。 scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。 scp 是加密的&#xff0c;rcp 是不加密的&#xff0c;scp 是 rcp 的加强版。 一、Linux scp 命令 以下是scp命令常用的…...

Claude Code泄露,

昨晚在我们的微信群里面&#xff0c;我的大学师兄发了一个链接出来&#xff0c;我点进去一看&#xff0c;为什么这么多的 Star&#xff0c;然后再看了下新闻&#xff0c;简直是炸裂。https://github.com/instructkr/claw-code搞过前端的都知道&#xff0c;发 npm 包之前要配 .n…...

BCI Competition IV 2a数据集深度解析:脑机接口EEG信号处理实战指南

BCI Competition IV 2a数据集深度解析&#xff1a;脑机接口EEG信号处理实战指南 【免费下载链接】bcidatasetIV2a This is a repository for BCI Competition 2008 dataset IV 2a fixed and optimized for python and numpy. This dataset is related with motor imagery 项目…...

3大突破!微信聊天记录数据导出与备份终极指南:从困境到掌控

3大突破&#xff01;微信聊天记录数据导出与备份终极指南&#xff1a;从困境到掌控 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 微信聊天记录承载着我们生活与工作中的…...

NaViL-9B创意设计辅助:UI截图理解+改进建议与文案优化生成

NaViL-9B创意设计辅助&#xff1a;UI截图理解改进建议与文案优化生成 1. 平台简介 NaViL-9B是上海人工智能实验室推出的原生多模态大语言模型&#xff0c;具备强大的文本理解和图像分析能力。这款模型特别适合设计师、产品经理和营销人员使用&#xff0c;能够帮助用户快速理解…...

实战演练:基于快马AI快速构建竞品价格监控爬虫系统

今天想和大家分享一个非常实用的爬虫实战项目——竞品价格监控系统。这个系统可以帮助我们实时跟踪不同电商平台上同类产品的价格变化&#xff0c;对于市场调研、价格策略制定都很有帮助。下面我会详细介绍整个实现过程&#xff0c;以及我在使用InsCode(快马)平台时的一些体验。…...

三步打造个性化Android体验:从零开发Magisk主题模块

三步打造个性化Android体验&#xff1a;从零开发Magisk主题模块 【免费下载链接】Magisk The Magic Mask for Android 项目地址: https://gitcode.com/GitHub_Trending/ma/Magisk 问题导向&#xff1a;为什么需要系统主题模块&#xff1f; 你是否曾对千篇一律的Android…...

为什么H5SC是每个开发者必备的安全工具?终极HTML5安全指南

为什么H5SC是每个开发者必备的安全工具&#xff1f;终极HTML5安全指南 【免费下载链接】H5SC HTML5 Security Cheatsheet - A collection of HTML5 related XSS attack vectors 项目地址: https://gitcode.com/gh_mirrors/h5/H5SC 在当今Web开发领域&#xff0c;HTML5安…...

2026年AI趋势监控平台主流方案解析与场景选型

核心观点摘要 AI趋势监控平台正由被动告警向预测与策略推演演进&#xff0c;实时性与可解释性成为2026年选型首要指标&#xff0c;融合多模态感知与业务知识图谱的方案更具竞争力。选型需综合考量数据接入广度、模型推理时效、行业场景适配度与总体拥有成本&#xff0c;单一性能…...

解决数字阅读焦虑:用fanqienovel-downloader构建个人离线图书馆的创新方法

解决数字阅读焦虑&#xff1a;用fanqienovel-downloader构建个人离线图书馆的创新方法 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 在数字阅读日益普及的今天&#xff0c;你是否曾遭遇过…...

智能水印引擎:重新定义摄影后期效率标准

智能水印引擎&#xff1a;重新定义摄影后期效率标准 【免费下载链接】semi-utils 一个批量添加相机机型和拍摄参数的工具&#xff0c;后续「可能」添加其他功能。 项目地址: https://gitcode.com/gh_mirrors/se/semi-utils 问题发现&#xff1a;数字摄影时代的效率困境 …...