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

什么是组合模式?一文详解

一.意图

将对象组合成树型结构,以表示“部分-整体”的层次结构。组合模式使得用户对单个对象(文件,由于文件是最底层,没儿子,所以叫“单个对象”)和组合对象(文件夹,文件夹有儿子,所以叫“组合对象”)的使用具有一致性(一致性的意思是,无论是文件还是文件夹,我们创建对象时,左面的声明类型都用抽象文件表示,这是一种多态的思想,很多算法都用到了)。

核心思想:

  • 文件夹下,可以包括文件、文件夹
  • 文件就不能进行add、和remove方法了(说白了,到文件就结束了,它不可能在下面继续深入添加儿子了,因为文件就到底了。再说白了,只有文件夹才能继续添加儿子)因此具体的做法就是(首先要知道,文件作为抽象文件的子类,是一定要实现抽象文件的add和remove方法,但是文件还不能进行add和remove,因此实现add和remove方法时,直接return “文件无法执行add、remove操作”之类的特殊处理信息即可。或者add和remove的返回值类型是boolean类型,那我们直接令文件的add和remove操作的返回值都是false即可,表示文件不能进行添加、删除儿子,因为文件就是最底层,没有儿子。)

二.结构

三.举例:文件夹、文件的树状结构(操作系统的目录结构)

1.代码

①创建“抽象文件”

//抽象文件(即:可以是文件夹,也可以是文件,故称为“抽象文件”) public abstract class AbstractFile { protected String name;//抽象文件的名称(即:文件夹的名称 / 文件的名称) //打印抽象文件的名称 public void printName(){ System.out.println(name); } //添加抽象文件(true代表添加成功、false代表添加失败) public abstract boolean add(AbstractFile file); //移除抽象文件(true代表移除成功、false代表移除失败) public abstract boolean remove(AbstractFile file); //获取子抽象文件组(儿子/子组件) public abstract List<AbstractFile> getChildren(); }

②创建“文件夹”

//文件夹 public class Folder extends AbstractFile{ //当前文件夹的子抽象文件组(儿子/子组件) private List<AbstractFile> childrenList = new ArrayList<AbstractFile>(); public Folder(String name){ this.name = name; } @Override public boolean add(AbstractFile file) { return childrenList.add(file); } @Override public boolean remove(AbstractFile file) { return childrenList.remove(file); } @Override public List<AbstractFile> getChildren() { return childrenList; } }

③创建“文件”

//文件 public class File extends AbstractFile{ public File(String name){ this.name = name; } @Override public boolean add(AbstractFile file) { return false;//文件就是最底层了,不能添加儿子,所以恒为false } @Override public boolean remove(AbstractFile file) { return false;//文件就是最底层了,不能移除儿子,所以恒为false } @Override public List<AbstractFile> getChildren() { return null;//文件就是最底层,根本不可能有儿子,所以返回null } }

测试一下

public class Demo01Application { //输出整体的树状结构 static void print(AbstractFile file){ //先输出自己的名字 file.printName(); //获取儿子集合 List<AbstractFile> childrenList = file.getChildren(); if(childrenList == null) return; //遍历每个儿子 for(AbstractFile children: childrenList){ //递归调用本方法 print(children);//这里要用递归,这也是一个考点 } } public static void main(String[] args) { AbstractFile root = new Folder("root"); AbstractFile folderA = new Folder("folderA"); AbstractFile folderB = new Folder("folderB"); AbstractFile fileC = new File("fileC"); AbstractFile fileD = new File("fileD"); AbstractFile fileE = new File("fileE"); root.add(folderA); root.add(folderB); root.add(fileC); folderA.add(fileD); folderA.add(fileE); //输出树状结构 print(root); } }

我们可以先根据常识,画一下目前代码中的目录结构:

所以此时遍历输出的结果顺序(先序遍历,即:根、左、右)应该是:
root、folderA、fileD、fileE、folderB、fileC

四.软考真题

1.2009年下半年

题目

分析过程

(1)abstract

(2)null

(3)List

(4)childList

(5)printTree(file)


没啥好说的,和我们上述举的例子一模一样。

正确答案

将我们上述的答案,和下面的正确答案进行对比,发现全对了。

2.2010年下半年

题目

分析过程

(1)abstract class

注意别把class丢了

(2)this.name

(3)Company

(4)Company

(5)children

(6)children

(7)root.Add(comp)

(8)comp.Add(comp1)


这题和文件、文件夹哪个类型的题一样,都是很简单的。

正确答案

将我们上述的答案,和下面的正确答案对比,发现全对了

http://www.zskr.cn/news/1334974.html

相关文章:

  • 【限时解密】Perplexity文化新闻搜索的“暗层过滤器”:3个未文档化content-type策略如何悄悄屏蔽非西方叙事?
  • 避坑指南:Lidar AI Solution环境配置中libprotobuf版本冲突与Python推理Segmentation fault解决实录
  • 说说Java HashMap的工作原理
  • 为服务器安全保驾护航的“三道防线”!
  • BGM自由!2026视频创作者必备的5个免费商用音乐素材库
  • 别再手动跑仿真了!用Simulink Test Manager搞定模型单元测试(附Excel数据对比)
  • 2026 AI面试软件Top5测评:鹅来面,你的全链路求职制胜法宝
  • 技术从业者的团队协作:如何打造高效的技术团队
  • Perplexity语言学习资源深度测评(2024Q2最新版):92%的学习者不知道的5个隐藏功能与3倍提效配置
  • RHCE第四次作业
  • 万字详解:普通开发者如何用Ollama、llama.cpp把大模型无缝跑在本地消费级显卡上?
  • Kaggle/天池竞赛新手必看:用LightGBM搞定银行客户认购预测(附完整代码与数据)
  • ART-PI FDCAN实战:从硬件连接到CubeMX配置与调试全解析
  • 告别.NET Framework:为什么我建议你的下一个WinForm项目直接上.NET 8?
  • AI 术语通俗词典:归一化层
  • MCU工程迁移实战:从STM32到MSPM0L1306的完整指南
  • 测试工程师的沟通技巧:如何向开发工程师反馈bug
  • 艺术家、策展人、博士生紧急收藏!Perplexity艺术知识检索失效的4大信号及实时修复协议
  • RISC-V RTOS任务栈与上下文切换:寄存器保存策略与栈初始化详解
  • 【Perplexity文学查询实战指南】:3大隐藏技巧让90%的文学研究效率提升300%
  • 华南及全国升降货梯专业品牌合规性排行盘点:广州液压升降机/广州液压升降货梯/广州液压简易升降机/广州液压货梯/广州直顶式升降机/选择指南 - 优质品牌商家
  • Shutter Encoder:专业视频编码与媒体处理的终极解决方案
  • 嵌入式Linux开发实战:FET-MX9352-C核心板系统启动、外设调试与稳定性优化全解析
  • Win10下搞定Realtek 8812BU网卡驱动,保姆级教程让Omnipeek抓包不再报错
  • 毕业设计 基于python的答题卡识别评分系统
  • 【Perplexity工程知识查询黄金标准】:基于127个真实故障案例构建的Query构造Checklist(含SOP模板)
  • Linux守护进程--进程、进程组、会话、终端
  • 2026年5月靠谱的湖北发电机出租联系方式哪家强厂家推荐榜,静音型/常规型/大型发电车租赁厂家选择指南 - 海棠依旧大
  • QGIS 3.28.3 保姆级教程:手把手教你下载天地图影像/矢量瓦片(附完整参数与避坑指南)
  • 终极Android虚拟定位指南:无需Root,让你的手机“瞬间移动“到世界任何角落!