Template模式

其实所有设计模式都是有EIT结构组成,EIT就好比原子,具体的模式好比分子,分子由原子组成。

比如现在要画两幅画,这两幅画的背景都是蓝天白云,其中一幅画的前景是海鸥,
另外一幅画的前景是风筝。那么应该把不变的部分提取到父类,也就是把背景提取到父类,变化的部分放到子类。

public class E
{
    public void  draw()
    {
        //蓝天白云
    }
}

public class T extends E
{
    public void draw()
    {
        draw();
        //海鸥
    }
}

//客户端代码
public class Client
{
    public void main()
    {
        E e = new T();
        e.draw();
    }
}

当调用e.draw(); 时会首先调用父类的 draw 再调用子类的 draw。
这是一种实现方式,但这种方式有个缺点就是,子类与父类有较大的依赖,父类的 draw方法被调用后,后面改版,维护的成本就大了。我们可以使用另外一种方式来实现就是
Template Month模式。

Template Method模式:

public class E
{
    public draw()   
    {
        //蓝天白云
        onDraw();
    }
    public void abstract onDraw();
}

public class T extends E
{
    public void onDraw()
    {
        //海鸥
    }   
}    


//客户端代码
public class Client
{
    public void main()
    {
        E e = new T();
        e.draw();
    }
}

这种由客户端代码来调用E的实体函数,再通过接口控制反转来执行T的 onDraw()
这种模式叫 TM模式。其中E的draw() 方法是叫 template方法,onDraw()叫 hook方法

TM设计模式虽然已经很优秀了,但仍然有个不好的地方,就是 Client 这里会用到 E 这个父类,那么当有很多Client (客户端用户不止一个厂商)使用了E,是的E变化的自由度就变低了,解决办法如下。

Template Month模式:

interface I
{
    public void  draw();
}


public class E implements  I
{
    public void draw()   
    {
        //蓝天白云
        onDraw();
    }
    public void abstract onDraw();
}

public class T extends E
{
    public void onDraw()
    {
        //海鸥
    }   
}    


//客户端代码
public class Client
{
    public void main()
    {
        I e = new T();
        e.draw();
    }
}