您的位置:首页 > 其它

组合模式(Composite Pattern)——管理良好的集合

2017-10-22 00:57 225 查看

前言

​ 最近由windows转到了Linux,但是似乎对Linux一无所知,只知道是装逼神器。但是慢慢滴,Linux的文件系统假装让我产生了兴趣(实际上是巧遇)。下面让我们来看看Linux文件系统的一段介绍。

​ Linux 系统中的一切都是存放在唯一的 虚拟文件系统中的,这个 虚拟文件系统是树状的结构以一个根目录开始。启动系统后,先有这个 虚拟文件系统,再识别出各个硬盘, 再把某个硬盘的某个分区挂载到这个 虚拟文件系统的某个子树上(即分区用某个子目录来表示),再确定分区对应的子目录文件系统,最后的文件就存放在这个特定的文件系统中。 也就是说, Linux 系统是通过 “虚拟文件系统-硬盘-硬盘上的分区-分区上的特定文件系统-特定文件系统中的文件” 这样的顺序来访问一个文件的。

​ 回到本文的主题。树形结构在软件中随处可见,例如操作系统中的目录结构、应用软件中的菜单、办公系统中的公司组织结构等等,如何运用面向对象的方式来处理这种树形结构就是组合模式需要解决的问题。

概述

组合模式(Composite Pattern)允许你将对象促合成树形结构来表现“整体/部分”层次结构。组合能让客户以一直的方式处理个别对象以及对象组合。

​ 换句话说,使用组合结构,我们能把相同的操作应用在组合和个别对象上,即,大多数情况下,我们可以忽略对象组合和个别对象之间的差别。好比,在数据结构中,对树节点的操作,不分根节点还是叶子节点。也就是一致性地处理树形结构中的叶子节点(不包含子节点的节点)和容器节点(包含子节点的节点)。

类图



设计模式的实现

总结

周一前补上
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: