03、装饰模式(Decorator)
一、概念:
动态的给一个对象添加一些额外的职责,就增加的功能来说,装饰模式比生成子类更为灵活。【DP】
二、通俗的理解:
装饰模式是利用其中的方法为来对对象进行包装的,这样每个包装对象的事项就和如何使用这个对象分离了,
每个对象只关心自己的功能,不需要关心如何添加到对象链中去。
三、模式类图

四、对类图的解释;
Component是定义一个对象接口,可以给这些对象动态的添加职责,ConcreateComponent是定义了一个具体的对象,
也可以给这个对象添加 一些职责。Decorator,装饰抽象类,继承了Componet,从外类来扩展Component类的功能,
但对于Component来说,是无需知道Descorator的存在的。至于ConcreteDescorator就是具体的装饰对象,起到给Component添加职责的功能。
五、类图代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Decorator
{
//Component类; public abstract class Component
{
public abstract void Operation(); //定义的接口中的实现方法
} public class ConcreteComponent : Component
{
public override void Operation()
{
Console.WriteLine("具体对象的实现操作");
}
} public class Decorator : Component
{
protected Component component; public void SetComponent(Component component)
{
//设置Component
this.component = component;
} public override void Operation()
//重写Operation(),实际是执行的是Component的Operation()
{
if (component != null)
{
component.Operation();
}
}
} public class ConcreteDecoratorA : Decorator
{
public override void Operation()
{
base.Operation(); //关键的一步
SubedBehavior();
Console.WriteLine("具体装饰对象A的操作");
}
public void SubedBehavior()
{
//用来区别ConcreateDecoratorA和 ConcreateDecoratorB的区别
}
} public class ConcreteDecoratorB : Decorator
{ public override void Operation()
{
base.Operation();
AddedBehavior();
Console.WriteLine("具体装饰对象B的操作");
}
public void AddedBehavior()
{
//用来区别ConcreateDecoratorA和 ConcreateDecoratorB的区别
}
} //客户端代码的实现;
class Program
{
static void Main(string[] args)
{
ConcreteComponent c = new ConcreteComponent();
ConcreteDecoratorA d1 = new ConcreteDecoratorA();
ConcreteDecoratorB d2 = new ConcreteDecoratorB(); d1.SetComponent(c);
d2.SetComponent(d1);
d2.Operation();
//装饰的方法是:首先用ConcreteComponent实例话对象c,然后用ConcreteDecorateA的实例化对象d1来包装c,在用ConcreteDecoratorB的对象d2来包装d1,最终执行d2的Operation() Console.ReadKey();
}
} }
六、结果显示

七、案例的使用:
在生活中我们时刻个电脑打交道,那么电脑就是我们补课或缺的一部分,那么我们肯定会给电脑进行添加东西,进行装饰了,
有外观上的装饰,同样也有内在的性能改变,这就用到了装饰模式了。对于电脑我们可以以性能的装饰来进行实例的演习。
性能中,我们可以加固态硬盘、内存条等。那么进行演示:
代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace Test_01
{ public abstract class Computer
{
public abstract void Show();
} public class HPComputer:Computer
{
public override void Show()
{
Console.WriteLine("以下是对惠普电脑的一系列操作");
}
} public class Decorator:Computer
{
protected Computer computer; public void SetCompueter(Computer computer)
{
this.computer = computer;
} public override void Show()
{
if(computer!=null)
{
computer.Show();
}
}
} public class SSD:Decorator
{
public override void Show()
{
base.Show();
Console.WriteLine("我的电脑加装了固态硬盘");
}
} public class Memory : Decorator
{
public override void Show()
{
base.Show();
Console.WriteLine("我的电脑加装了内存条");
}
} class Program
{
static void Main(string[] args)
{
HPComputer decorator = new HPComputer();
SSD ssd = new SSD();
Memory memory = new Memory(); ssd.SetCompueter(decorator);
memory.SetCompueter(ssd);
memory.Show();
Console.ReadKey();
}
}
}
运行结果

八、结语:到底在什么地方使用装饰模式
当系统需要新功能的时候,是向旧的类中添加新的代码,这些新加的代码通常装饰了原有类的核心职责或主要行为。
装饰模式是提供了一个非常好的解决方案,他把每个要装饰的功能放在单独的类中,并让这个类包装他所要装饰的对象,因此当需要执行特殊操作行为时,
客户代码就可以在运行时根据需要有选择的,按顺序的使用装饰功能 包装对象了【DP】
优点
1、装饰者模式比继承更灵活
2、可以通过一种动态的方式来扩展一个对象的功能,在运行时选择不同的装饰器,从而实现不同的行为。
3、通过使用不同的具体装饰类以及这些装饰类的排列组合,可以创造出很多不同行为的组合。
缺点
1、会产生很多小对象,增加了系统的复杂性。
2、更加易于出错,排错也很困难,较为烦琐。
03、装饰模式(Decorator)的更多相关文章
- 装饰模式/decorator模式/结构型模式
装饰模式Decorator 定义 为对象动态的增加新的功能,实现要求装饰对象和被装饰对象实现同一接口或抽象类,装饰对象持有被装饰对象的实例. java实现要点 定义一个接口或抽象类,作为被装饰者的抽象 ...
- 二十四种设计模式:装饰模式(Decorator Pattern)
装饰模式(Decorator Pattern) 介绍动态地给一个对象添加一些额外的职责.就扩展功能而言,它比生成子类方式更为灵活.示例有一个Message实体类,某个对象对它的操作有Insert()和 ...
- 乐在其中设计模式(C#) - 装饰模式(Decorator Pattern)
原文:乐在其中设计模式(C#) - 装饰模式(Decorator Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 装饰模式(Decorator Pattern) 作者:weba ...
- 设计模式 装饰模式(Decorator)
设计模式 装饰模式(Decorator) @author ixenos 装饰模式是什么 1.装饰模式以对客户端透明的方式对象的功能,是继承关系的一个替代方案,但装饰模式可以在不创造更多子类的情况下,对 ...
- 设计模式-装饰模式(Decorator Pattern)
装饰模式(Decorator Pattern):动态地给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活
- Netty学习-IO体系架构系统回顾 & 装饰模式Decorator的具体使用
Netty学习-IO体系架构系统回顾 IO和NIO的学习 NIO - 1.4 开始出的 在网络应用框架中,NIO得到了大量的使用,特别是netty里面 前提:对IO及其了解 对IO的总结和回顾 理解J ...
- 设计模式-09装饰模式(Decorator Pattern)
1.模式动机 一般有两种方式可以实现给一个类或对象增加行为: 继承机制:使用继承机制是给现有类添加功能的一种有效途径,通过继承一个现有类可以使得子类在拥有自身方法的同时还拥有父类的方法.但是这种方法是 ...
- 设计模式系列之装饰模式(Decorator Pattern)——扩展系统功能
说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...
- 装饰模式 - Decorator 和 外观模式 - Facade
装饰模式 Decorator,不改变接口但动态给对象加入责任,所需功能按顺序串联起来控制,比生成子类灵活. 外观模式 Facade,让接口更简单.为子系统中的一组接口提供一个一致的界面. 参考:
- [工作中的设计模式]装饰模式decorator
一.模式解析 装饰模式又名包装(Wrapper)模式.装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案. 装饰模式的要点主要是: 1.需要对已有对象扩展新的功能,又不希望改变原有对 ...
随机推荐
- 「白帽黑客成长记」Windows提权基本原理(上)
我们通常认为配置得当的Windows是安全的,事实真的是这样吗?今天让我们跟随本文作者一起深入了解Windows操作系统的黑暗角落,看看是否能得到SYSTEM权限. 作者将使用不同版本的Windows ...
- maven 学习---Maven构建自动化-Hudson
建立自动化定义场景,依赖项目建设过程中被启动,一旦项目生成成功完成,以确保相关的项目是稳定的. 实例 考虑一个团队正在开发一个项目总线核心API上的其他两个项目的应用程序,网页UI和应用程序的桌面UI ...
- RT-Thread点亮led
下载默认工程 https://www.rt-thread.org/ 配置rtconfig.h #define STM32F103RE //修改成自己的板子 #define RT_HSE_VALUE 8 ...
- flink WaterMark之TumblingEventWindow
1.WaterMark,翻译成水印或水位线,水印翻译更抽象,水位线翻译接地气. watermark是用于处理乱序事件的,通常用watermark机制结合window来实现. 流处理从事件产生,到流经s ...
- Golang 需要避免踩的 50 个坑(三)
前言 Go 是一门简单有趣的编程语言,与其他语言一样,在使用时不免会遇到很多坑,不过它们大多不是 Go 本身的设计缺陷.如果你刚从其他语言转到 Go,那这篇文章里的坑多半会踩到. 如果花时间学习官方 ...
- cocos2dx3.x + xcode7.3 问题“libpng error: CgBI: unhandled critical chunk”
今天用 cocos2dx3.11.1 + xcode7.3.1 进行开发,新建项目后遇到如下问题: 在iphone(ios9.3.5)真机运行项目(用xcode自带虚拟机没有出现问题) auto sp ...
- 分母为0的坑(float)
分母不能为0 对于int 类型,如果分母为0,在程序运行时,会报错. 而对于float 类型,如果分母为0,则不会报错,而是会返回一个infinity(无穷大),也就是NAN. 因为除一个无穷小的数, ...
- html5 localStorage讲解
早期的web中使用cookies在客户端保存诸如用户名等简单的信息,但是,在使用cookies存储永久数据存在以下问题. 1.cookies的大小限制在4kB,不适合大量的数据存储. 2.浏览器还限制 ...
- Shell:
Bash Notes for professionals ebook https://blog.csdn.net/simple_the_best/article/details/52821136 27 ...
- LeetCode 154. Find Minimum in Rotated Sorted Array II寻找旋转排序数组中的最小值 II (C++)
题目: Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. ( ...