- 浏览: 593720 次
- 性别:
- 来自: 福建
文章分类
最新评论
-
18335864773:
用 pageoffice 吧. http://www.zhuo ...
使用Jacob输出word文档 -
dick1305:
很好,谢谢分享。
XFire创建WebService实例 -
wd530141534:
<c:if test="${ReleaseRe ...
Axis2创建WebService实例 -
wd530141534:
if(result != null && re ...
Axis2创建WebService实例 -
wd530141534:
String printerIp = req.getRemot ...
Axis2创建WebService实例
装饰模式:
1. 动态地给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活。
2. 通过使用不同的具体装饰类以及这些装饰类的排列组合,设计师可以创造出很多不同行为的组合。
/** * Component定义一个对象的接口,可以给这些对象动态地添加职责。 * */ public abstract class Component { public abstract void operation(); }
/** * ConcreteComponent定义了一个具体的对象,也可以给这个对象添加一些职责。 * */ public class ConcreteComponent extends Component { @Override public void operation() { System.out.println("具体对象的操作"); } }
/** * 装饰抽象类,继承Component,从外类来扩展Component类的功能。但对于Component来说,是 * 无须知道Decorator类的存在的。至于ConcreteComponent就是具体的装饰对象,起到给 * Component添加职责的功能。 * */ public abstract class Decorator extends Component { protected Component component; public void setComponent(Component component) { this.component = component; } //重写operation,实际执行的是Component的operation(); @Override public void operation() { if(component!=null){ component.operation(); } } }
/** * 具体装饰对象A * */ public class ConcreteDecoratorA extends Decorator { // 本类独有的功能,以区别于ConcreteDecoratorrB private String addedState; @Override public void operation() { // TODO Auto-generated method stub super.operation(); addedState = "New State"; System.out.println("具体装饰对象A的操作。"); } }
/** * 具体装饰对象B * */ public class ConcreteDecoratorB extends Decorator { @Override public void operation() { super.operation(); this.addBehaviorr(); System.out.println("具体装饰对象B的操作。"); } /** * 本类独有的方法,以区别于ConcreteDecoratorA */ private void addBehaviorr(){ } }
public class Main { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub ConcreteComponent c = new ConcreteComponent(); ConcreteDecoratorA d1 = new ConcreteDecoratorA(); ConcreteDecoratorB d2 = new ConcreteDecoratorB(); /** 装饰的方法是:首先用ConcreteComponent实例化对象C, 然后用ConcreteDecoratorA的实例化对象d1来包装c, 再用ConcreteDecoratorB的实例化对象d2包装d1,最终执行d2.operation(); 装饰模式是利用setComponent来对对象进行包装的,这样每个装饰对象的实现就 和如何使用这个对象分离开了,每个装饰对象只关心自己的功能, 不需要关心如何被添加到对象链当中。**/ d1.setComponent(c); d2.setComponent(d1); d2.operation(); } }
装饰模式实例:(衣服装扮)
/** * Person类,具体的对象类ConcreteComponet * */ public class Person { private String name; public Person(){ } public Person(String name){ this.name = name; } public void show(){ System.out.println("装扮的"+name); } }
/** * 服饰类(Decorator) * */ public class Finery extends Person { private Person person; // 装扮(setComponent) public void decorate(Person person) { this.person = person; } @Override public void show() { if(person!=null){ person.show(); } } }
/** * 具体的服饰类大T恤(ConcreteDecorator) * */ public class FineryTShirts extends Finery { @Override public void show() { // TODO Auto-generated method stub System.out.print("大T恤 "); super.show(); } }
/** * 具体的服饰类垮裤(ConcreteDecorator) * */ public class FineryBigTrouser extends Finery { @Override public void show() { // TODO Auto-generated method stub System.out.print("垮裤 "); super.show(); } }
/** * 具体的服饰类皮鞋(ConcreteDecorator) * */ public class FineryLeatherShoes extends Finery { @Override public void show() { // TODO Auto-generated method stub System.out.print("皮鞋 "); super.show(); } }
/** * 具体的服饰类运动鞋(ConcreteDecorator) * */ public class FinerySneakers extends Finery { @Override public void show() { // TODO Auto-generated method stub System.out.print("运动鞋 "); super.show(); } }
public class Main { public static void main(String[] args) { Person person = new Person("小王"); FineryTShirts shirts = new FineryTShirts(); FineryBigTrouser bigTrouser = new FineryBigTrouser(); FinerySneakers sneakers = new FinerySneakers(); FineryLeatherShoes leatherShoes = new FineryLeatherShoes(); System.out.println("第一种装扮:"); sneakers.decorate(person); bigTrouser.decorate(sneakers); shirts.decorate(bigTrouser); shirts.show(); System.out.println("第二种装扮:"); leatherShoes.decorate(person); bigTrouser.decorate(leatherShoes); shirts.decorate(bigTrouser); shirts.show(); } }
运行结果如下:
第一种装扮: 大T恤 垮裤 运动鞋 装扮的小王 第二种装扮: 大T恤 垮裤 皮鞋 装扮的小王
发表评论
-
设计模式的一些相关原则
2011-06-23 17:01 1384面向对象的三大特性 ... -
访问者模式
2011-06-23 16:31 1797访问者模式:表示一个作用于某对象结构中的各元素的操作。它使 ... -
模板方法模式
2011-06-23 11:16 1176模板方法模式:定义一个操作中的算法的骨架,而将一些步骤迟到 ... -
策略模式
2011-06-23 10:29 1124策略模式: 定义了算 ... -
状态模式
2011-06-22 16:34 1288状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象 ... -
单例模式
2011-06-22 15:30 1267单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点 ... -
代理模式
2011-06-22 15:14 1017代理模式:为其它对象提供一种代理,以控制对这个对象的访问。 ... -
原型模式
2011-06-22 14:36 1081原型模式:用原型实例指定创建对象的种类,并且通过拷贝这些原型 ... -
观察者模式
2011-06-17 10:46 1258观察者模式(发布-订 ... -
备忘录模式
2011-06-16 10:58 1041备忘录模式:在不破坏封装性的前提下,捕获一个对象的内部状态 ... -
中介者模式
2011-06-16 10:10 1866中介者模式:用一个中介对象来封装一系列的对象交互,从而降低 ... -
迭代器模式
2011-06-15 11:17 2883迭代器模式:提供一种方法顺序访问一个聚合对象中各个元素,而又不 ... -
解释器模式
2011-06-15 10:44 1298解释器模式:给定一个语言,定义它的文法的一种表示。并定义一个 ... -
享元模式
2011-06-14 11:22 1088享元模式:运用共享技术有效地支持大量细粒度的对象。 ... -
抽象工厂模式
2011-06-14 10:42 1252抽象工厂模式:提供一个创建一系列相关或相互依赖对象的接口, ... -
简单工厂与工厂方法模式
2011-06-13 16:38 1156简单工厂模式:由一个工厂对象决定创建出哪一种产品类的实例。 ... -
外观模式
2011-06-13 15:08 1087外观模式:为子系统中的一组接口提供一个一致的界面,此模式定义了 ... -
命令模式
2011-04-21 17:40 1232命令模式:将一个请求 ... -
桥接模式
2011-04-20 21:24 1383桥接模式:将抽象部分与他的实现部分分离,使它们都可以独立地变化 ... -
职责链模式
2011-04-20 21:23 1284职责链模式:使多个对 ...
相关推荐
### 开发模式之装饰模式详解 #### 装饰模式定义 装饰模式(Decorator Pattern)是一种结构型设计模式,允许向对象动态地添加新的功能,而无需修改其原有结构。这种模式通过创建一个新的包装类来包裹真实的对象,...
装饰模式是一种设计模式,它允许我们在不修改原有对象的基础上,通过添加新的行为或属性来扩展对象的功能。在"装饰模式小猪快跑游戏模拟"这个实例中,我们看到这种模式被巧妙地应用到了一个名为“小猪吃苹果”的游戏...
装饰模式是一种结构型设计模式,它允许我们向一个对象动态地添加新的行为或责任,而无需修改该对象的源代码。在C#中,装饰模式是通过创建一个包装类(Decorator),该包装类实现了与被装饰对象相同的接口,并持有被...
【装饰模式】是一种设计模式,源自Erich Gamma等人编写的《设计模式:可重用面向对象软件的基础》一书。这种模式在Swing开发中尤为常见,用于增强或改进现有对象的功能,尤其在Web应用程序中,如Java的J2EE环境,...
装饰模式是一种设计模式,属于结构型模式,其主要目的是在不改变对象本身的基础上,通过向对象添加新的行为或属性来扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭。 在装饰模式中,有四个关键...
装饰模式是一种结构型设计模式,它允许在运行时给对象添加新的行为或责任,而无需修改对象的源代码。在Java中,装饰模式通常通过继承和组合来实现,提供了比子类化更灵活的方式来扩展对象的功能。 装饰模式的核心...
装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在软件工程中非常常见,因为它提供了灵活性,使得我们可以独立于对象的组合来扩展功能。 在C++中,装饰...
装饰模式是一种结构型设计模式,它允许在运行时动态地给对象添加新的行为或属性,而不必修改原有类的代码。这种模式的核心在于装饰者和组件接口的统一,使得装饰者可以替代原对象并添加额外的功能。在"设计模式之...
装饰模式(Decorator)是软件设计领域中一种非常实用的结构型设计模式,它允许我们向一个对象添加新的行为或责任,而无需修改该对象的源代码。在C++编程语言中,装饰模式常用于动态地扩展类的功能,使得类的行为在...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。装饰模式通常用于为已有对象添加...
装饰模式(Decorator Pattern)是设计模式中的一种结构型模式,它在不改变原有对象的基础上,通过添加额外的职责来扩展对象的功能。在C#中,装饰模式尤其适用于那些需要动态地增加或减少对象功能的情况,避免了使用...
装饰模式是一种设计模式,它允许在不改变对象自身的情况下,动态地给对象添加新的行为或职责。这种模式常用于在不修改源代码的情况下扩展对象的功能,或者为对象提供额外的职责。在本例中,"项目经理接到一个项目,...
装饰模式是一种设计模式,它允许我们在不改变对象本身的情况下,为对象添加新的行为或属性,从而扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭,这意味着我们可以灵活地增加一个对象的功能,而...
装饰模式是一种结构型设计模式,它允许我们向现有的对象添加新的功能,同时又不破坏其原有的结构。在C#中,装饰模式常用于在运行时动态地改变对象的行为,而无需修改原始类的代码。这种模式的核心在于装饰者类与被...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或职责,而无需修改对象的源代码。这种模式在软件工程中非常有用,因为它提供了灵活性,使得代码可以在不破坏封装性的前提下进行扩展。 在"实验九:装饰...
装饰模式是一种设计模式,它允许在不修改对象本身的情况下,通过包装(或“装饰”)对象来动态地扩展其功能。在面向切面编程(Aspect Oriented Programming, AOP)中,装饰模式常被用来实现在运行时向目标对象添加...
装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式通常用于保持对象的原始类结构不变,同时增强其功能。HeadFirst 设计模式系列书籍以其生动有趣的插图和...
装饰模式是一种结构型设计模式,它允许我们向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。在《Head First设计模式》一书...
装饰模式是一种结构型设计模式,它是面向对象设计中用来动态添加或修改对象功能的一种方法。在软件工程中,装饰模式允许我们向一个现有的对象添加新的行为或职责,同时又不改变其原有的结构,从而实现对类的功能扩展...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在Java等面向对象编程语言中非常常见,因为它提供了灵活性,使得扩展对象的功能变得容易且优雅。在这个"装饰...