结构型模式之组合模式

概述

对于树形结构,当容器对象(如文件夹)的某一个方法被调用时,将遍历整个树形结构,寻找也包含这个方法的成员对象(可以是容器对象,也可以是叶子对象)并调用执行,牵一而动百,其中使用了递归调用的机制来对整个结构进行处理。由于容器对象和叶子对象在功能上的区别,在使用这些对象的代码中必须有区别地对待容器对象和叶子对象,而实际上大多数情况下我们希望一致地处理它们,因为对于这些对象的区别对待将会使得程序非常复杂。组合模式为解决此类问题而诞生,它可以让叶子对象和容器对象的使用具有一致性

定义

组合模式(Composite Pattern):组合多个对象形成树形结构以表示具有“整体—部分”关系的层次结构。组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性,组合模式又可以称为“整体—部分”(Part-Whole)模式,它是一种对象结构型模式。

实现

顶层基类

    public abstract class File
    {
        public string name { get; set; }
        public File(string name)
        {
            this.name = name;
        }
        /// <summary>
        /// 显示文件方法
        /// </summary>
        public virtual void Display()
        {
            Console.WriteLine(name);
        }
    }

容器类

    public class Folder : File
    {
        /// <summary>
        /// 文件集合
        /// </summary>
        private List<File> files;

        public Folder(string name) : base(name)
        {
            files = new List<File>();
        }
        /// <summary>
        /// 新增文件方法
        /// </summary>
        /// <param name="file"></param>
        public void Add(File file)
        {
            files.Add(file);
        }

        public void Remove(File file)
        {
            files.Remove(file);
        }

        public override void Display()
        {
            base.Display();
            files.ForEach(p =>
            {
                p.Display();
            });
        }
    }

叶子节点类

    public class ImageFile : File
    {
        public ImageFile(string name) : base(name)
        { }
        public override void Display()
        {
            Console.WriteLine(base.name);
        }
    }
    public class TextFile : File
    {
        public TextFile(string name) : base(name)
        { }
        public override void Display()
        {
            Console.WriteLine(base.name);
        }
    }

客户端

        static void Main(string[] args)
        {
            Folder folder = new Folder("总文件夹");
            folder.Add(new TextFile(string.Format("{0}日记文件.txt", GetLevelString(1))));
            folder.Add(new ImageFile(string.Format("{0}毕业照.JPG", GetLevelString(1))));
            Folder level_One_Folder = new Folder(string.Format("{0}1级文件夹", GetLevelString(1)));
            level_One_Folder.Add(new TextFile(string.Format("{0}盗墓笔记.txt", GetLevelString(2))));
            level_One_Folder.Add(new ImageFile(string.Format("{0}亵渎.txt", GetLevelString(2))));
            folder.Add(level_One_Folder);
            Folder level_Two_Folder = new Folder(string.Format("{0}2级文件夹", GetLevelString(2)));
            level_Two_Folder.Add(new TextFile(string.Format("{0}廊桥遗梦.txt", GetLevelString(3))));
            level_Two_Folder.Add(new ImageFile(string.Format("{0}陈乔恩.JPG", GetLevelString(3))));
            folder.Add(level_Two_Folder);
            folder.Display();
            Console.ReadLine();
        }

        static string GetLevelString(int level)
        {
            StringBuilder sb = new StringBuilder();
            for (var i = 0; i < level; i++)
            {
                sb.Append("\t");
            }
            return sb.ToString();
        }

总结

主要优点

1、组合模式可以清楚地定义分层次的复杂对象,表示对象的全部或部分层次,它让客户端忽略了层次的差异,方便对整个层次结构进行控制。

2、 客户端可以一致地使用一个组合结构或其中单个对象,不必关心处理的是单个对象还是整个组合结构,简化了客户端代码。

3、 在组合模式中增加新的容器构件和叶子构件都很方便,无须对现有类库进行任何修改,符合“开闭原则”。

4、 组合模式为树形结构的面向对象实现提供了一种灵活的解决方案,通过叶子对象和容器对象的递归组合,可以形成复杂的树形结构,但对树形结构的控制却非常简单。

主要缺点

在增加新构件时很难对容器中的构件类型进行限制。有时候我们希望一个容器中只能有某些特定类型的对象,例如在某个文件夹中只能包含文本文件,使用组合模式时,不能依赖类型系统来施加这些约束,因为它们都来自于相同的抽象层,在这种情况下,必须通过在运行时进行类型检查来实现,这个实现过程较为复杂

时间: 2024-12-14 18:49:40

结构型模式之组合模式的相关文章

结构型设计模式之组合模式

结构 意图 将对象组合成树形结构以表示“部分-整体”的层次结构.C o m p o s i t e 使得用户对单个对象和组合对象的使用具有一致性. 适用性 你想表示对象的部分-整体层次结构. 你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象. 1 using System; 2 using System.Collections; 3 4 abstract class Component 5 { 6 protected string strName; 7 8 publi

java-设计模式(结构型)-【组合模式】

1.组合模式(Composite) 定义:组合模式有时又叫部分-整体模式在处理类似树形结构的问题时比较方便 使用场景:将多个对象组合在一起进行操作,常用于表示树形结构中,例如二叉树,数等,文件目录. 2.文件复制例子 文件类: //对文件各种操作的接口 public interface FileOperate { void copy(); } //file:单个文件 class File implements FileOperate { //文件名 private String fileName

12结构型模式之组合模式

概念 Composite模式也叫组合模式,是构造型的设计模式之一.通过递归手段来构造树形的对象结构,并可以通过一个对象来访问整个对象树. 角色和职责 Component (树形结构的节点抽象) - 为所有的对象定义统一的接口(公共属性,行为等的定义) - 提供管理子节点对象的接口方法 - [可选]提供管理父节点对象的接口方法 Leaf (树形结构的叶节点) Component的实现子类 Composite(树形结构的枝节点) Component的实现子类 适用于: 单个对象和组合对象的使用具有一

(38)23种设计模式研究之九【迭代器模式和组合模式】

一.定义 迭代器可以认为是一个指针,可以遍历容器的指针.迭代器(iterator)有时又称游标(cursor)是程式设计的软件设计模式,可在容器物件(container,例如链表或阵列)上遍访的接口,设计人员无需关心容器物件的内容迭代器(iterator)是一种对象,它能够用来遍历标准模板库容器中的部分或全部元素,每个迭代器对象代表容器中的确定的地址.迭代器修改了常规指针的接口,所谓迭代器是一种概念上的抽象:那些行为上像迭代器的东西都可以叫做迭代器.然而迭代器有很多不同的能力,它可以把抽象容器和

迭代器模式和组合模式混用

迭代器模式和组合模式混用 前言 园子里说设计模式的文章算得上是海量了,所以本篇文章所用到的迭代器设计模式和组合模式不提供原理解析,有兴趣的朋友可以到一些前辈的设计模式文章上学学,很多很有意思的.在Head First 设计模式这本书中,也有说迭代和组合模式混用的方法,但是使用的语言是JAVA,实现起来比起C#差异还是不少.本人在做几个C#小项目的时候需要用到树形结构,也看到了Head First 设计模式中混用迭代器和组合模式的例子,觉得如果能用C#实现,以后无疑会带来很大的帮助.下面就记录下实

&quot;围观&quot;设计模式(17)--结构型之享元模式(Flyweight Pattern)

享元模式(英语:Flyweight Pattern)是一种软件设计模式.它使用共享物件,用来尽可能减少内存使用量以及分享资讯给尽可能多的相似物件:它适合用于当大量物件只是重复因而导致无法令人接受的使用大量内存.通常物件中的部分状态是可以分享.常见做法是把它们放在外部数据结构,当需要使用时再将它们传递给享元.----WIKIPEDIA 个人理解 共享,内存消耗大的时候应考虑对象的共享,共享对象可以减少对象的生成数量,这样可以减少内存的消耗,当一个对象和其他的对象存在共性且内容一致的时候,可以将共有

设计模式(结构型)之装饰者模式(Decorator Pattern)

PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbober] 阅读前一篇<设计模式(结构型)之组合模式(Composite Pattern)>http://blog.csdn.net/yanbober/article/details/45392513 概述 装饰模式可以在不改变一个对象本身功能的基础上给对象增加额外的新行为.装饰模式是一种用于替代继承

设计模式(结构型)之享元模式(Flyweight Pattern)

PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbober] 阅读前一篇<设计模式(结构型)之外观模式(Facade Pattern)>http://blog.csdn.net/yanbober/article/details/45476527 概述 当一个软件系统在运行时产生的对象数量太多,将导致运行代价过高,带来系统性能下降等问题.所以需要采用一

迭代器模式和组合模式

迭代器模式: 提供一种方法顺序访问聚合对象内的各个元素,而又不暴露其内部的表示 实现Iterator接口的hasNext()以及next()方法 组合模式: 允许你将对象组合成树形结构来表现"整体/部分"层次结构,组合能让客户以一致的方式处理个别对象以及对象组合