图解设计模式Template Method模式

2017-01-12  本文已影响243人  MWY

组成模版的方法被定义在父类中,这些方法是抽象方法,所以只查看父类的代码是无法知道这些方法最终会进行何种具体的处理,唯一能知道的就是父类是如何调用这些方法的。
实现上述这些抽象方法的是子类,在子类中实现了抽象方法也就决定了具体的处理过程,也就是说,只要在不同的子类中实现不同的具体处理,当父类的模版方法被调用时程序的行为也就不同。
这种在父类中定义处理流程,在子类中实现具体处理的模式就是Template Method模式

UML
Paste_Image.png
AbstractDisplay(抽象类)
public abstract class AbstractDisplay {
    public abstract void open();
    public abstract void print();
    public abstract void close();
    public final void display() {
        open();
        for (int i = 0; i < 5; i++) {
            print();
        }
        close();
    }
}
CharDisplay(具体类)
public class CharDisplay extends AbstractDisplay {
    private char ch;
    public CharDisplay(char ch) {
        this.ch = ch;
    }
    @Override
    public void open() {
        System.out.print("<<");
    }

    @Override
    public void print() {
        System.out.print(ch);
    }

    @Override
    public void close() {
        System.out.println(">>");
    }
}
StringDisplay(具体类)
public class StringDisplay extends AbstractDisplay {
    private String string;
    private int width;
    public StringDisplay(String string) {
        this.string = string;
        this.width = string.getBytes().length;
    }


    @Override
    public void open() {
        printLine();
    }

    @Override
    public void print() {
        System.out.println("|" + string + "|");
    }

    @Override
    public void close() {
        printLine();
    }

    private void printLine() {
        System.out.print("+");
        for (int i = 0; i < width; i++) {
            System.out.print("-");
        }
        System.out.println("+");
    }
}

Main
public class Main {

    public static void main(String[] args) {
    // write your code here
        AbstractDisplay d1 = new CharDisplay('H');
        AbstractDisplay d2 = new StringDisplay("Hello, World.");

        d1.display();
        d2.display();
    }
}
Template Method模式的优点
上一篇下一篇

猜你喜欢

热点阅读