《《模板方法模式》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《模板方法模式》PPT课件.ppt(26页珍藏版)》请在三一办公上搜索。
1、第6章,模板方法模式,本章教学内容,模板方法模式 模式动机与定义 模式结构与分析 模式实例与解析 模式效果与应用,操作流程包含步骤!,模板方法模式,模式动机,模板方法模式,模式动机模板方法模式是基于继承的代码复用基本技术,模板方法模式的结构和用法也是面向对象设计的核心之一。在模板方法模式中,可以将相同的代码放在父类中,而将不同的方法实现放在不同的子类中。在模板方法模式中,我们需要准备一个抽象类,将部分逻辑以具体方法以及具体构造函数的形式实现,然后声明一些抽象方法来让子类实现剩余的逻辑。不同的子类可以以不同的方式实现这些抽象方法,从而对剩余的逻辑有不同的实现,这就是模板方法模式的用意。模板方法模
2、式体现了面向对象的诸多重要思想,是一种使用频率较高的模式。,模板方法模式,模式定义模板方法模式(Template Method Pattern):定义一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。,模板方法模式,模式定义Template Method Pattern:Define the skeleton of an algorithm in an operation,deferring some steps to subclasses.Template Method lets subclasses redefine c
3、ertain steps of an algorithm without changing the algorithms structure.Frequency of use:medium,模板方法模式,模式结构,模板方法模式,模式结构模板方法模式包含如下角色:AbstractClass:抽象类 ConcreteClass:具体子类,模板方法模式,模式分析模板方法模式是一种类的行为型模式,在它的结构图中只有类之间的继承关系,没有对象关联关系。在模板方法模式的使用过程中,要求开发抽象类和开发具体子类的设计师之间进行协作。一个设计师负责给出一个算法的轮廓和骨架,另一些设计师则负责给出这个算法的各个
4、逻辑步骤。实现这些具体逻辑步骤的方法称为基本方法(Primitive Method),而将这些基本法方法汇总起来的方法称为模板方法(Template Method),模板方法模式的名字从此而来。,模板方法模式,模式分析模板方法:一个模板方法是定义在抽象类中的、把基本操作方法组合在一起形成一个总算法或一个总行为的方法。基本方法:基本方法是实现算法各个步骤的方法,是模板方法的组成部分。抽象方法(Abstract Method)具体方法(Concrete Method)钩子方法(Hook Method):“挂钩”方法和空方法,模板方法模式,模式分析钩子方法(Hook Method),模板方法模式,模
5、式分析典型的抽象类代码如下所示:,模板方法模式,模式分析典型的具体子类代码如下所示:,模板方法模式,模式分析在模板方法模式中,由于面向对象的多态性,子类对象在运行时将覆盖父类对象,子类中定义的方法也将覆盖父类中定义的方法,因此程序在运行时,具体子类的基本方法将覆盖父类中定义的基本方法,子类的钩子方法也将覆盖父类的钩子方法,从而可以通过在子类中实现的钩子方法对父类方法的执行进行约束,实现子类对父类行为的反向控制。,模板方法模式,模板方法模式实例与解析实例一:银行业务办理流程 在银行办理业务时,一般都包含几个基本步骤,首先需要取号排队,然后办理具体业务,最后需要对银行工作人员进行评分。无论具体业务
6、是取款、存款还是转账,其基本流程都一样。现使用模板方法模式模拟银行业务办理流程。,模板方法模式,模板方法模式实例与解析实例一:银行业务办理流程,模板方法模式,模板方法模式实例与解析实例二:计算存款利息 假设系统需要支持两种存款账号,即货币市场(Money Market)账号和定期存款(Certificate of Deposite)账号。这两种账号的存款利息是不同的,因此,在计算一个存户的存款利息额时,必须区分两种不同的账号类型。这个系统的总行为应当是计算出利息,这也就决定了作为一个模板方法模式的顶级逻辑应当是利息计算。由于利息计算涉及到两个步骤:一个基本方法给出账号种类,另一个基本方法给出利
7、息百分比。这两个基本方法构成具体逻辑,因为账号的类型不同,所以具体逻辑会有所不同。显然,系统需要一个抽象角色给出顶级行为的实现,而将两个作为细节步骤的基本方法留给具体子类实现。由于需要考虑的账号有两种:一是货币市场账号,二是定期存款账号。系统的类结构如下图所示。,模板方法模式,模板方法模式实例与解析实例二:计算存款利息,模板方法模式,模板方法模式实例与解析实例三:数据库操作模板 对数据库的操作一般包括连接、打开、使用、关闭等步骤,在数据库操作模板类中我们定义了connDB()、openDB()、useDB()、closeDB()四个方法分别对应这四个步骤。对于不同类型的数据库(如SQL Ser
8、ver和Oracle),其操作步骤都一致,只是连接数据库connDB()方法有所区别,现使用模板方法模式对其进行设计。,模板方法模式,模板方法模式实例与解析实例三:数据库操作模板,模板方法模式,模式优缺点模板方法模式的优点模板方法模式在一个类中形式化地定义算法,而由它的子类实现细节的处理。模板方法模式是一种代码复用的基本技术。,模板方法模式,模式优缺点模板方法模式的缺点每个不同的实现都需要定义一个子类,这会导致类的个数增加,系统更加庞大,设计也更加抽象,但是更加符合“单一职责原则”,使得类的内聚性得以提高。,模板方法模式,模式适用环境在以下情况下可以使用模板方法模式:一次性实现一个算法的不变的
9、部分,并将可变的行为留给子类来实现。各子类中公共的行为应被提取出来并集中到一个公共父类中以避免代码重复。对一些复杂的算法进行分割,将其算法中固定不变的部分设计为模板方法和父类具体方法,而一些可以改变的细节由其子类来实现。控制子类的扩展。,本章小结,在模板方法模式中,定义一个操作中算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。模板方法是一种类行为型模式。模板方法模式包含两个角色:在抽象类中定义一系列基本操作,这些基本操作可以是具体的,也可以是抽象的,同时,在抽象类中实现了一个模板方法,用于定义一个算法的骨架;具体子类是抽象类的子类,
10、用于实现在父类中定义的抽象基本操作以完成子类特定算法的步骤,也可以覆盖在父类中实现的具体基本操作。在模板方法模式中,方法可以分为模板方法和基本方法,其中基本方法又可以分为抽象方法、具体方法和钩子方法,钩子方法根据其特点又分为空方法和与实现算法步骤的基本方法“挂钩”的方法。,本章小结,模板方法模式的优点在于在子类定义详细的处理算法时不会改变算法的结构,实现了代码的复用,通过对子类的扩展可以增加新的行为,符合“开闭原则”;其缺点在于需要为每个不同的实现都定义一个子类,这会导致类的个数增加,系统更加庞大,设计也更加抽象模板方法模式适用情况包括:一次性实现一个算法的不变的部分,并将可变的行为留给子类来实现;各子类中公共的行为应被提取出来并集中到一个公共父类中以避免代码重复;对一些复杂的算法进行分割,将其算法中固定不变的部分设计为模板方法,而一些可以改变的细节由其子类来实现;通过模板方法模式还可以控制子类的扩展。,END,Thanks!,