java设计模式--模板方法模式
2020-12-13 04:26
标签:第一行代码 print xtend 固定 detail ext test ide span 模板方法模式:用来定义一个操作中的算法的骨架,将一些具体步骤延迟到子类中。 具体的子类A,实现了父类的抽象方法。 具体的子类B,同样实现了父类的抽象方法,但是实现的具体细节和A不同 测试方法 测试结果: 模板代码........ConcreteClassA DetailOperation1....ConcreteClassA DetailOperation2....模板代码结束....... 总结:当我们要完成一系列的步骤时,有一部分实现的细节不同,其他的操作都相同时,我们可以考虑使用模板方法模式,把不变的操作提炼到父类,不同的实现细节放到子类,这样就提高了代码的复用性。 java设计模式--模板方法模式 标签:第一行代码 print xtend 固定 detail ext test ide span 原文地址:https://www.cnblogs.com/yimengyizhen/p/11109772.html//定义一个抽象类
public abstract class AbstractClass{
//抽象方法1,实现延迟到子类实现
public abstract void DetailOperation1(StringBuffer stringBuffer);
//抽象方法2,同上
public abstract void DetailOperation2(StringBuffer stringBuffer);
//模板方法,给出了逻辑的骨架
public void tempalte(){
StringBuffer stringBuffer = new StringBuffer();
//一些固定的操作可以直接在该类实现 例如该注释下的第一行代码,另外一些细节可能产生变化的操作就把他们的实现放到子类去实现,如DetailOperation1()
stringBuffer.append("模板代码........");
DetailOperation1(stringBuffer);
DetailOperation2(stringBuffer);
stringBuffer.append("模板代码结束.......");
System.out.println(stringBuffer);
}
}public class ConcreteClassA extends AbstractClass {
@Override
public void DetailOperation1(StringBuffer stringBuffer) {
stringBuffer.append("ConcreteClassA DetailOperation1....");
}
@Override
public void DetailOperation2(StringBuffer stringBuffer) {
stringBuffer.append("ConcreteClassA DetailOperation2....");
}
}
public class ConcreteClassB extends AbstractClass {
@Override
public void DetailOperation1(StringBuffer stringBuffer) {
stringBuffer.append("ConcreteClassB DetailOperation1....");
}
@Override
public void DetailOperation2(StringBuffer stringBuffer) {
stringBuffer.append("ConcreteClassB DetailOperation2....");
}
}
public class Test {
public static void main(String[] args) {
AbstractClass concreteClassA = new ConcreteClassA();
concreteClassA.tempalte();
AbstractClass concreteClassB = new ConcreteClassB();
concreteClassB.tempalte();
}
}
模板代码........ConcreteClassB DetailOperation1....ConcreteClassB DetailOperation2....模板代码结束.......