结构图
1. 扩展点在抽象类AbstractClass的实现子类。
2. 每一个实现子类实现一种抽象方法的算法实现,子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
3. 客户端可以替换不同的子类实现。
4. 定义一个操作的算法骨架,而将一些步骤延迟到子类中实现,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
类设计
模式说明
1. 扩展点在抽象类AbstractClass的实现子类。
2. 每一个实现子类实现一种抽象方法的算法实现,子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
3. 客户端可以替换不同的子类实现。
4. 定义一个操作的算法骨架,而将一些步骤延迟到子类中实现,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
客户端
public static void main(String[] args) {
AbstractClass ac = null;
// use A class
ac = new ConcreteClassA();
ac.templateMethod();
// use B class
ac = new ConcreteClassB();
ac.templateMethod();
}
类设计
public abstract class AbstractClass {
public void templateMethod() {
primitiveOperation1();
System.out.println("process template method.");
primitiveOperation2();
}
public abstract void primitiveOperation1();
public abstract void primitiveOperation2();
}
public class ConcreteClassA extends AbstractClass {
@Override
public void primitiveOperation1() {
System.out.println("primitive operation1 in A");
}
@Override
public void primitiveOperation2() {
System.out.println("primitive operation1 in A");
}
}
public class ConcreteClassB extends AbstractClass {
@Override
public void primitiveOperation1() {
System.out.println("primitive operation1 in B");
}
@Override
public void primitiveOperation2() {
System.out.println("primitive operation1 in B");
}
}