设计模式10-装饰模式

1. 概念

 动态地给一个对象添加一些额外的职责。就增加功能来说,Decorator模式相比生成子类更为灵活

2. 案例

/**********************************************************************
 * <pre>
 * FILE : Demo01.java
 * CLASS : Demo01
 *
 * AUTHOR : Liaokailin
 *
 * FUNCTION : TODO
 *
 *
 *======================================================================
 * CHANGE HISTORY LOG
 *----------------------------------------------------------------------
 * MOD. NO.|   DATE   |   NAME  | REASON  | CHANGE REQ.
 *----------------------------------------------------------------------
 *             |2014-3-6|Liaokailin| Created |
 * DESCRIPTION:
 * </pre>
 ***********************************************************************/
package org.demo.decorate.demo01;
/**
 * 动态地给一个对象添加一些额外的职责。就增加功能来说,Decorator模式相比生成子类更为灵活。
 * 适用性
    1.在不影响其他对象的情况下,以动态、透明的方式给单个对象添加职责。
    2.处理那些可以撤消的职责。
    3.当不能采用生成子类的方法进行扩充时。
    
    参与者
    1.Component
    定义一个对象接口,可以给这些对象动态地添加职责。
    2.ConcreteComponent
    定义一个对象,可以给这个对象添加一些职责。
    3.Decorator
    维持一个指向Component对象的指针,并定义一个与Component接口一致的接口。
    4.ConcreteDecorator
    向组件添加职责。
 */

//component
interface Person{
    void eat() ;
}

//ConcreteComponent 

class Man implements Person{
    @Override
    public void eat() {
        System.out.println("Man: eat");
    }
}
//Decorate 
abstract class Decorator implements Person{
    protected Person person ;
    public void setPerson(Person person){
        this.person = person ;
    }
    public void eat(){
        person.eat() ;
    }
}
//ConcreteDecorate

class ConcreteDecorate extends Decorator{
    public void eat(){
        System.out.println("wash before each meal");
        super.eat() ;
        System.out.println("wipe mouth");
    }
}


public class Demo01 {
   public static void main(String[] args) {
    Man m = new Man() ;
    ConcreteDecorate c = new ConcreteDecorate() ;
    c.setPerson(m) ; //装饰man
    c.eat() ;
}
}

 

    运行结果: 

wash before each meal
Man: eat
wipe mouth

3. 案例二

    

/**********************************************************************
 * <pre>
 * FILE : Demo02.java
 * CLASS : Demo02
 *
 * AUTHOR : Liaokailin
 *
 * FUNCTION : TODO
 *
 *
 *======================================================================
 * CHANGE HISTORY LOG
 *----------------------------------------------------------------------
 * MOD. NO.|   DATE   |   NAME  | REASON  | CHANGE REQ.
 *----------------------------------------------------------------------
 *             |2014-3-6|Liaokailin| Created |
 * DESCRIPTION:
 * </pre>
 ***********************************************************************/
package org.demo.decorate.demo02;

interface DrinkComponent{
    float getTotalCost() ;
    String getDescription() ;
}


class Espresso implements DrinkComponent{
    private String description = "Espresso" ;
    private float cost = 0.75f  ;
    public float getTotalCost() {
        return cost;
    }
    public String getDescription() {
        return description;
    }
}


class EspressoConPanna implements DrinkComponent {
      private String description = "EspressoConPare";
      private float cost = 1;
      public float getTotalCost() {
        return cost;
      }
      public String getDescription() {
        return description;
      }
    }


abstract class Decorator implements DrinkComponent{
    protected DrinkComponent component ;
    public Decorator(DrinkComponent component){
        this.component = component ;
    }
    @Override
    public float getTotalCost(){
        return component.getTotalCost() ;
    }
    
     public String getDescription() {
            return component.getDescription();
      }
}

class ExtraEspresso extends Decorator{
    private float cost = 1f ;
    public ExtraEspresso(DrinkComponent component){
        super(component) ;
    }
    @Override
    public float getTotalCost() {
        return super.getTotalCost()+cost;
    }

    @Override
    public String getDescription() {
        return super.getDescription() +"extra espresso";
    }
    
}
public class Demo02 {
   public static void main(String[] args) {
       Espresso espresso = new Espresso() ; //DrinkComponent ;
       ExtraEspresso decorate = new ExtraEspresso(espresso) ;
       System.out.println("coffer:"+decorate.getDescription()+";totalCost:"+decorate.getTotalCost() );
       
}
}

 

执行结果: 

     

coffer:Espressoextra espresso;totalCost:1.75

 

 

4. 案例三

    

/**********************************************************************
 * <pre>
 * FILE : Demo03.java
 * CLASS : Demo03
 *
 * AUTHOR : Liaokailin
 *
 * FUNCTION : TODO
 *
 *
 *======================================================================
 * CHANGE HISTORY LOG
 *----------------------------------------------------------------------
 * MOD. NO.|   DATE   |   NAME  | REASON  | CHANGE REQ.
 *----------------------------------------------------------------------
 *             |2014-3-6|Liaokailin| Created |
 * DESCRIPTION:
 * </pre>
 ***********************************************************************/
package org.demo.decorate.demo03;
/**
 * 写一个简单的系统,
 * 用decorator模式模拟以下情况:
 * 有些鸟会飞而有一些不会,
 * 有一些鸟会游泳而有一些不会,
 * 还有一些既会飞又会游泳。
 * 
 * 分析  如果写一个bird类 然后继承生成各种bird  这显然不合理的  bird太多  导致子类过多 。
 * 但是为了给bird增加一些功能  如: fly swim
 */

 
interface Bird{
    void type() ; //类型 
}

class Bird01 implements Bird{
    public void type() {
        System.out.print(" a bird :");
    }
}

 
abstract class Decorator implements Bird{
    protected Bird bird ;
    public Decorator(Bird bird){
        this.bird = bird ;
    }
    
    public void type(){
        bird.type() ;
    }
}

class Decorator01 extends Decorator{

    public Decorator01(Bird bird) {
        super(bird);
    }
    @Override
    public void type() {
        super.type();
        System.out.println(" only can fly ");
    }
} 

class Decorator02 extends Decorator{

    public Decorator02(Bird bird) {
        super(bird);
    }
    @Override
    public void type() {
        super.type();
        System.out.println(" only can swim ");
    }
} 


class Decorator03 extends Decorator{

    public Decorator03(Bird bird) {
        super(bird);
    }
    @Override
    public void type() {
        super.type();
        System.out.println(" not only fly,but also swim ");
    }
} 


public class Demo03 {
    public static void main(String[] args) {
        Bird b = new Bird01() ;
        Decorator d1 = new Decorator03(b) ;
        d1.type();
    }
}

 

执行结果:

 

 a bird : not only fly,but also swim 

 

 

    

 

 

 

 

 

 

 

 

 

   

 

 

 

 

 

 

 

posted @ 2014-06-20 18:07  廖凯林  阅读(132)  评论(0编辑  收藏  举报