设计模式——模版方法模式

在阎宏博士的《JAVA与模式》一书中开头是这样描述模板方法(Template Method)模式的:模板方法模式是类的行为模式。准备一个抽象类,将部分逻辑以具体方法以及具体构造函数的形式实现,然后声明一些抽象方法来迫使子类实现剩余的逻辑。不同的子类可以以不同的方式实现这些抽象方法,从而对剩余的逻辑有不同的实现。这就是模板方法模式的用意。

在模版方法模式中,通过在模版抽象类中定义一个操作的算法骨架,将一些步骤抽取封装到具体的抽象方法中,强迫子类进行按需要重写实现方法,这样使得在使用的时候,子类可以不改变算法结构即可重新定义算法的特定步骤。模版方法模式是基于继承代码复用的基本技术。

模版方法模式结构

模版方法模式UML

TemplateMethod.png

模版方法模式涉及的角色

  • 抽象模板角色(AbstractTemplate):抽象模版类,用来定义算法的基本骨架,同时定义一个或多个抽象操作,这些操作由子类进行实现。
  • 具体模板角色(ConcreteTemplate):具体模板角色,用来实现算法骨架中的某些步骤,完成与特定子类相关的功能。

案例演示

这里我们以登录作为一个演示的例子,我们都知道,登录模块有会员登录和普通用户登录,这两块在登录权限处理上有所不同。

定义抽象模版登录模块

/**
 * 声明一个抽象模版类
 * @author Iflytek_dsw
 *
 */
abstract class AbstractLogin {
    /**
     * 登录的过程可以分为以下几个步骤:
     * 1、密码加密;
     * 2、用户验证;
     */
    public void login(String userName, String pwd){
        encryptPwd(pwd);
        loginUser(userName,pwd);
    }
    
    protected abstract void loginUser(String userName, String pwd);
    
    /**
     * 密码加密
     * @param pwd
     */
    private void encryptPwd(String pwd){
        System.out.println("密码加密");
    }
}

在抽象登录模块中,我们定义了声明了一个方法encryptPwd,同时声明了一个loginUser的抽象函数。

定义具体的模板方法类

/**
 * 普通用户登录
 * @author Iflytek_dsw
 *
 */
class NormalLogin extends AbstractLogin{

    @Override
    public void loginUser(String userName, String pwd) {
        System.out.println("普通用户登录:"+ userName);
    }
}

/**
 * 会员用户登录
 * @author Iflytek_dsw
 *
 */
class MemberLogin extends AbstractLogin{

    @Override
    public void loginUser(String userName, String pwd) {
        System.out.println("会员用户登录" + userName);
    }
}

根据权限角色不同,登录的方法有所区别,即子类重写父类预留的模板方法。

客户端

public class Client {

    /**
     * @param args
     */
    public static void main(String[] args) {
        AbstractLogin normalLogin = new NormalLogin();
        AbstractLogin memberLogin = new MemberLogin();
        
        normalLogin.login("andoter的学习笔记", "dsw123");
        memberLogin.login("Andoter学习笔记", "andoter123");
    }
}

执行结果

密码加密
普通用户登录
密码加密
会员用户登录

通过上面的例子,我们可以看到,模板方法的核心就是固定算法的骨架结构,它的UML图跟策略模式非常相似,本质上这两种模式还是有很大差异的。策略模式侧重的不同的策略,模板方法模式侧重的是某个处理流程中的关键节点代码不确定,范围比策略模式小。

模板方法中的方法

根据上面的介绍,模板方法中的方法可以分为两大类:模板方法和基本方法。

模板方法

  • 一个模板方法是定义在抽象类中的,把基本操作方法组合在一起形成一个总算法或一个总行为的方法。
  • 一个抽象类可以有任意多个模板方法,而不限于一个。每一个模板方法都可以调用任意多个具体方法。

基本方法

  • 抽象方法:一个抽象方法由抽象类声明,由具体子类实现。在Java语言里抽象方法以abstract关键字标示。
  • 具体方法:一个具体方法由抽象类声明并实现,而子类并不实现或置换。
  • 钩子方法:一个钩子方法由抽象类声明并实现,而子类会加以扩展。通常抽象类给出的实现是一个空实现,作为方法的默认实现。

模板方法优缺点

优点

  • 良好的复用性,通过将公共的方法集中在模板类中,将公共不同部分抽取出来放到子类中实现达到复用的效果。
  • 扩展性比较好,封装不变的,扩展可变部分。
  • 易于维护

缺点

  • 骨架固定,升级不易。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,056评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,842评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,938评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,296评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,292评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,413评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,824评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,493评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,686评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,502评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,553评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,281评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,820评论 3 305
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,873评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,109评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,699评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,257评论 2 341

推荐阅读更多精彩内容