`
clq9761
  • 浏览: 592507 次
  • 性别: Icon_minigender_1
  • 来自: 福建
社区版块
存档分类
最新评论

装饰模式

阅读更多

  装饰模式:

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恤 垮裤 皮鞋 装扮的小王

 

 

 

  • 大小: 38.1 KB
分享到:
评论

相关推荐

    开发模式之装饰模式

    ### 开发模式之装饰模式详解 #### 装饰模式定义 装饰模式(Decorator Pattern)是一种结构型设计模式,允许向对象动态地添加新的功能,而无需修改其原有结构。这种模式通过创建一个新的包装类来包裹真实的对象,...

    装饰模式小猪快跑游戏模拟

    装饰模式是一种设计模式,它允许我们在不修改原有对象的基础上,通过添加新的行为或属性来扩展对象的功能。在"装饰模式小猪快跑游戏模拟"这个实例中,我们看到这种模式被巧妙地应用到了一个名为“小猪吃苹果”的游戏...

    设计模式之装饰模式

    装饰模式是一种结构型设计模式,它允许我们向一个对象动态地添加新的行为或责任,而无需修改该对象的源代码。在C#中,装饰模式是通过创建一个包装类(Decorator),该包装类实现了与被装饰对象相同的接口,并持有被...

    用装饰模式装饰HttpServletRequest对象

    【装饰模式】是一种设计模式,源自Erich Gamma等人编写的《设计模式:可重用面向对象软件的基础》一书。这种模式在Swing开发中尤为常见,用于增强或改进现有对象的功能,尤其在Web应用程序中,如Java的J2EE环境,...

    装饰模式——装饰模式.doc

    装饰模式是一种设计模式,属于结构型模式,其主要目的是在不改变对象本身的基础上,通过向对象添加新的行为或属性来扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭。 在装饰模式中,有四个关键...

    JAVA设计模式之装饰模式代码

    装饰模式是一种结构型设计模式,它允许在运行时给对象添加新的行为或责任,而无需修改对象的源代码。在Java中,装饰模式通常通过继承和组合来实现,提供了比子类化更灵活的方式来扩展对象的功能。 装饰模式的核心...

    设计模式 - 装饰模式(C++实例)

    装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在软件工程中非常常见,因为它提供了灵活性,使得我们可以独立于对象的组合来扩展功能。 在C++中,装饰...

    设计模式之装饰模式:以售卖咖啡为例

    装饰模式是一种结构型设计模式,它允许在运行时动态地给对象添加新的行为或属性,而不必修改原有类的代码。这种模式的核心在于装饰者和组件接口的统一,使得装饰者可以替代原对象并添加额外的功能。在"设计模式之...

    设计模式C++学习之装饰模式(Decorator)

    装饰模式(Decorator)是软件设计领域中一种非常实用的结构型设计模式,它允许我们向一个对象添加新的行为或责任,而无需修改该对象的源代码。在C++编程语言中,装饰模式常用于动态地扩展类的功能,使得类的行为在...

    装饰模式代码示例

    装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。装饰模式通常用于为已有对象添加...

    C#设计模式之Decorator 装饰模式

    装饰模式(Decorator Pattern)是设计模式中的一种结构型模式,它在不改变原有对象的基础上,通过添加额外的职责来扩展对象的功能。在C#中,装饰模式尤其适用于那些需要动态地增加或减少对象功能的情况,避免了使用...

    利用装饰模式,实现编写项目经理接到一个项目,需要完成编码

    装饰模式是一种设计模式,它允许在不改变对象自身的情况下,动态地给对象添加新的行为或职责。这种模式常用于在不修改源代码的情况下扩展对象的功能,或者为对象提供额外的职责。在本例中,"项目经理接到一个项目,...

    装饰模式小应用

    装饰模式是一种设计模式,它允许我们在不改变对象本身的情况下,为对象添加新的行为或属性,从而扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭,这意味着我们可以灵活地增加一个对象的功能,而...

    C# 装饰模式实例

    装饰模式是一种结构型设计模式,它允许我们向现有的对象添加新的功能,同时又不破坏其原有的结构。在C#中,装饰模式常用于在运行时动态地改变对象的行为,而无需修改原始类的代码。这种模式的核心在于装饰者类与被...

    实验九:装饰模式.rar

    装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或职责,而无需修改对象的源代码。这种模式在软件工程中非常有用,因为它提供了灵活性,使得代码可以在不破坏封装性的前提下进行扩展。 在"实验九:装饰...

    装饰模式实现AOP

    装饰模式是一种设计模式,它允许在不修改对象本身的情况下,通过包装(或“装饰”)对象来动态地扩展其功能。在面向切面编程(Aspect Oriented Programming, AOP)中,装饰模式常被用来实现在运行时向目标对象添加...

    HeadFirst 设计模式学习笔记3--装饰模式 Demo

    装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式通常用于保持对象的原始类结构不变,同时增强其功能。HeadFirst 设计模式系列书籍以其生动有趣的插图和...

    装饰模式简单例子

    装饰模式是一种结构型设计模式,它允许我们向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。在《Head First设计模式》一书...

    23种设计模式--装饰模式

    装饰模式是一种结构型设计模式,它是面向对象设计中用来动态添加或修改对象功能的一种方法。在软件工程中,装饰模式允许我们向一个现有的对象添加新的行为或职责,同时又不改变其原有的结构,从而实现对类的功能扩展...

    装饰模式生成密码实例

    装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在Java等面向对象编程语言中非常常见,因为它提供了灵活性,使得扩展对象的功能变得容易且优雅。在这个"装饰...

Global site tag (gtag.js) - Google Analytics