设计模式 - 模版方法模式 Template Method

模版方法模式简介

定义
	定义一个操作中的算法的骨架,而将一些步骤延迟到子类中,
	模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤
典型描述
	自己做饭吃的例子
	父类定义
		第一步:买菜
		第二步:洗菜
		第三步:做菜
		第四步:吃菜
		第五步:洗碗
	子类定义
		第一步:去那里买菜(父类不关心,买回来就成)
		第二步:用什么洗菜(父类不关心,洗干净就成)
		第三步:菜做的好不好(父类不关心,能做出来就成)
		第四步:怎么吃菜(父类不关心,吃进肚子就成)
		第五步:用什么洗碗(父类不关心,洗干净就成)
	子类不能改变父类的步骤
使用场合
	把不变的行为放在父类,把可变的行为留给子类来完成
	各子类公共的行为应该被提取并集中到一个公共父类中以避免重复
	控制子类的扩展
模版方法的组成部分
	父类角色:提供模版
	子类角色:为模版提供实现

模板方法模式案例

/*****************定义模版****************/
package com.itlwc;

/*
 定义父类角色(模版)
 模版内容
 	方法必须按顺序执行,method1,method2,method3
 */
public abstract class AbstractClass {
	public abstract void method1();

	public abstract void method2();

	public abstract void method3();

	// 定义骨架 (接口不能实现模版,因为接口不能有非抽象方法,导致不能定义模版的骨架)
	public void template() {
		this.method1();
		this.method2();
		this.method3();
	}
}

/*****************为模版提供实现***************/
package com.itlwc;

/*
 定义子类角色(为模版提供实现)
 */
public class ConcreteClass extends AbstractClass {

	@Override
	public void method1() {
		System.out.println("执行方法一");
	}

	@Override
	public void method2() {
		System.out.println("执行方法二");
	}

	@Override
	public void method3() {
		System.out.println("执行方法三");
	}
}

/**************测试类*******************/
package com.itlwc;

public class Test {
	public static void main(String[] args) {
		AbstractClass a = new ConcreteClass();
		a.template();
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值