模版模式

定义

    定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤

主要解决

   多个子类有相同的方法,并且逻辑相同,细节有差异。

如何解决

   对重要,复杂的算法,将核心算法设计为模板方法,周边细节由子类实现,重构时,经常使用的方法,将相同的代码抽象到父类,通过钩子函数约束行为。

关键代码

   在抽象类实现通用接口,细节变化在子类实现。

缺点

   每一个不同的实现都需要一个子类来实现,导致类的个数增加,使得系统更加庞大。

class Computer  
{  
public:  
    void product()  
    {  
        installCpu();  
        installRam();  
        installGraphicsCard();  
    }  
  
protected:  
    virtual    void installCpu() = 0;  
    virtual void installRam() = 0;  
    virtual void installGraphicsCard() = 0;  
  
};  
  
class ComputerA:public Computer  
{  
protected:  
    void installCpu() override  
    {  
        cout << "ComputerA install Inter Core i5" << endl;  
    }  
  
    void installRam() override  
    {  
        cout << "ComputerA install 2G Ram" << endl;  
    }  
  
    void installGraphicsCard() override  
    {  
        cout << "ComputerA install Gtx940 GraphicsCard" << endl;  
    }  
};  
  
class ComputerB:public Computer  
{  
protected:  
    void installCpu() override  
    {  
        cout << "ComputerB install Inter Core i7" << endl;  
    }  
  
    void installRam() override  
    {  
        cout << "ComputerB install 4G Ram" << endl;  
    }  
  
    void installGraphicsCard() override  
    {  
        cout << "ComputerB install Gtx960 GraphicsCard" << endl;  
    }  
};  

参考:

https://www.yuque.com/docs/share/cee37579-d078-483a-bff0-8ec6aad1e9e5

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值