《C++新经典设计模式》之第2章 模板方法模式

《C++新经典设计模式》之第2章 模板方法模式

模板方法模式.cpp
cpp 复制代码
#include <iostream>
#include <memory>
using namespace std;

// 动态绑定,多态,稳定+变化
// 稳定,内部函数调用顺序固定
// 变化,内部具体函数调用由各子类决定

namespace ns1
{
    class Warrior // "战士"类
    {
        int m_life;   // 生命值
        int m_magic;  // 魔法值
        int m_attack; // 攻击力

    public:
        Warrior(int life, int magic, int attack) : m_life(life), m_magic(magic), m_attack(attack) {}

    public:
        void JN_Burn() // 技能"燃烧"
        {
            m_life -= 300;
            cout << "Lose 500 HP points for each enemy" << endl;
            cout << "The protagonist loses 300 HP" << endl;
            cout << "Play the special effect of the \"burning\" skill to the players" << endl;
        }
    };
}

namespace ns2
{
    class Fighter // 战斗者父类
    {
    protected:
        int m_life;   // 生命值
        int m_magic;  // 魔法值
        int m_attack; // 攻击力

    public:
        Fighter(int life, int magic, int attack) : m_life(life), m_magic(magic), m_attack(attack) {}
        virtual ~Fighter() {}
        void JN_Burn() // 技能"燃烧"
        {
            if (canUseJN()) // 如果能使用该技能
            {
                effect_enemy(); // 对敌人产生的影响
                effect_self();  // 对主角自身产生的影响

                play_effect(); // 播放技能"燃烧"的技能特效
            }
        }

    private:
        virtual bool canUseJN() const = 0; // 判断是否能使用技能"燃烧",纯虚函数声明,子类中必须实现

    private:
        virtual void effect_enemy() const {}
        virtual void effect_self() {}

    private:
        void play_effect() const { cout << "Play the special effect of the \"burning\" skill to the players" << endl; }
    };

    class F_Warrior : public Fighter // "战士"类
    {
    public:
        F_Warrior(int life, int magic, int attack) : Fighter(life, magic, attack) {}

    private:
        bool canUseJN() const override { return m_life >= 300; }

    private:
        void effect_enemy() const override
        {
            cout << "Lose 500 HP points for each enemy" << endl;
        }
        void effect_self() override
        {
            cout << "The protagonist loses 300 HP" << endl;
            m_life -= 300;
        }
    };

    class F_Mage : public Fighter // "法师"类
    {
    public:
        F_Mage(int life, int magic, int attack) : Fighter(life, magic, attack) {}

    private:
        bool canUseJN() const override { return m_magic >= 100; }

    private:
        void effect_enemy() const override
        {
            cout << "Lose 650 HP points for each enemy" << endl;
        }
        void effect_self() override
        {
            cout << "The protagonist loses 100 MV" << endl;
            m_magic -= 100;
        }
    };
}

int main()
{
#if 0
    using namespace ns1;
    shared_ptr<Warrior> mroleobj(new Warrior(1000, 0, 200));
    mroleobj->JN_Burn();
#endif

#if 1
    using namespace ns2;
    shared_ptr<Fighter> fighter(new F_Warrior(1000, 0, 200));
    fighter->JN_Burn();
    cout << "-------------------------" << endl;
    fighter.reset(new F_Mage(800, 200, 300));
    fighter->JN_Burn();
#endif

    cout << "Over!\n";
    return 0;
}
相关推荐
g***B7381 小时前
前端组件设计模式,复用与扩展
前端·设计模式
2501_941111992 小时前
C++中的装饰器模式变体
开发语言·c++·算法
桦说编程2 小时前
如果让我从头再来学习并发编程
java·设计模式·性能优化
怕什么真理无穷2 小时前
C++_面试15_零拷贝
c++·面试·职场和发展
AA陈超2 小时前
ASC学习笔记0007:用于与GameplayAbilities系统交互的核心ActorComponent
c++·笔记·学习·ue5·虚幻引擎
大袁同学2 小时前
【哈希hash】:程序的“魔法索引”,实现数据瞬移
数据结构·c++·算法·哈希算法·散列表
沐怡旸3 小时前
【穿越Effective C++】条款21:必须返回对象时,别妄想返回其reference——对象返回的语义与效率平衡
c++·面试
2501_941112613 小时前
C++与Docker集成开发
开发语言·c++·算法
智者知已应修善业3 小时前
【51单片机:两边向中间流水:即两边先点亮然后熄灭,次边的点亮再熄灭,直到最中间的两个点亮再熄灭,然后重复动作。】2023-3-4
c语言·c++·经验分享·笔记·嵌入式硬件·算法·51单片机
明洞日记3 小时前
【设计模式手册006】建造者模式 - 复杂对象的优雅构建之道
java·设计模式·建造者模式