设计模式——装饰模式

2017-05-23  本文已影响0人  书笔年华

设计模式———装饰模式

例子:成绩单报告

在面向对象的设计中,如果超过两层继承,可能就出设计问题了。这是经验总结,并非定论。继承层次越多,维护成本越多。

成绩装饰模型
增加一个抽象类和两个实现类,其中Decorator的作用是封装SchoolReort类
抽象成绩单
//抽象成绩单
public abstract class SchoolReport{
  public abstract void report();
  public abstract void sign(String name);
}
具体的四年级成绩
public abstract FourthGradeSchoolReport extends SchoolReport{
  public void report(){
    System.out.println("尊敬的XX家长");
    System.out.println("成绩如下");
    System.out.println("语文xx");
    // ...
  }
  public void sign(String name){
    System.out.println("家长签名为:"+name);
  }
}
修饰的抽象类
// 修饰的抽象类
public abstract class Decorator extends SchoolReport{
  private SchoolReport sr;
  public Decorator(SchoolReport sr){
    this.sr = sr;
  }
  // 报告成绩
  public void report(){
    this.sr.report();
  }
  //家长签名
  public void sign(String name){
    this.sr.sign(name);
  }
}
最高成绩修饰
public class HighScoreDecorator extends Decorator  {
  public HighScoreDecorator(SchoolReport sr){
    super(sr);
  }
  private void reportHighScore(){
    System.out.println("最高成绩是:XX");
  }
  public void report(){
    this.reportHighScore();
    super.report();
  }
}
排名情况修饰
public class SortDecorator extends Decorator   {
  public SortDecorator(SchoolReport sr){
    super(sr);
  }
  public void reportSort(){
    System.out.println("排名情况是xx");
  }
  @Override
  public void report(){
    this.reportSort();
    super.report();
  }
}
查看成绩单
public class Father{
  public static void main(String[] args) {
    //把成绩单拿过来
    SchoolReport sr;
    //原装的成绩单
    sr = new FourthGradeSchoolReport();
    //加了最高分说明的成绩单
    sr = new HighScoreDecorator(sr);
    // 加了排名的说明
    sr = new SortDecorator(sr);
    //看成绩单
    sr.report();
    sr.sign("name");
  }
}

装饰模式的定义

Attach additional responsibilities to an object dynamically keeping the same interface. Decorators provide a flexible alternative to subclassing for extending functionality.

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

装饰模式
四个角色说明
抽象构件
public abstract class Component{
  //抽象的方法
  public abstract void operate();
}
具体构件
public class ConcreteComponent extends Component  {
  // 具体实现
  public void operate(){
    // code to do something
    System.out.println("doSomethin");
  }
}
抽象装饰者
public abstract class Decorator extends Component{
  //必然有一个变量是抽象构件
  private Component component = null;
  //通过构造函数传递被修饰者
  public Decorator(Component component){
    this.component = component;
  }
  //委托给被修饰者执行
  @Override
  public void operate(){
    this.component.operate();
  }
}
具体的装饰类
public class ConcreteDecorator1 extends Decorator{
  public ConcreteDecorator1(Component component){
    super(component);
  }
  //定义自己的修饰方法
  public void method(){
    //code to do something
  }
  public void operate(){
    this.method();
    super.operate();
  }
}
public class ConcreteDecorator2 extends Decorator{
  public ConcreteDecorator2(Component component){
    super(component);
  }
  //定义自己的修饰方法
  public void method(){
    //code to do something
  }
  public void operate(){
    this.method();
    super.operate();
  }
}
场景类
public class Client{
  public static void main(String[] args) {
    Component component = new ConcreteComponent();
    // 第一次修饰
    component = new ConcreteDecorator1(component);
    // 第二次修饰
    component = new ConcreteDecorator2(component);
    //运行结果
    component.operate();
  }
}

装饰模式的优缺点

装饰模式的优点
装饰模式的缺点
装饰模式的使用场景
上一篇下一篇

猜你喜欢

热点阅读