c++设计模式之状态模式

状态模式思想:定义一个状态类,里面可以实现多种状态的转换,每个状态由一个单独类来判断和实现,对象里有设置更新状态的方法,获得当前状态的方法来跳转到其他状态类的方法中(因为setstate的时候把state的状态变为另一个子类,然后调用子类自己的判断方法,满足条件,则用new一个新状态代替原来状态来跳转->使用对象的getstate,此时调用的“当前状态函数”是new出来状态的对象的(即父类的子类方法实现接管- -))  总结:状态方法判断,达到条件,对象执行set新状态方法,对象get到新状态的Currentstate然后转到新状态自己判断方法中!#include <iostream>#include <string>#include <vector>

using namespace std;class War;class State{public:    virtual void Prophase() {}    virtual void Metaphase() {}    virtual void Anaphase() {}    virtual void End() {}    virtual void CurrentState(War *war) {}};//战争class War{private:    State *m_state;  //目前状态    int m_days;      //战争持续时间public:    War(State *state)            : m_state(state),              m_days(0)    {}    ~War()    {        delete m_state;    }    int GetDays()    {        return m_days;    }    void SetDays(int days)    {        m_days = days;    }    void SetState(State *state)    {        delete m_state; m_state = state;    }    void GetState()    {        m_state->CurrentState(this);    }};

//战争结束class EndState: public State{public:    void End(War *war) //结束阶段的具体行为    {        cout<<"战争结束"<<endl;    }    void CurrentState(War *war) { End(war); }};//后期class AnaphaseState: public State{public:    void Anaphase(War *war) //后期的具体行为    {        if(war->GetDays() < 30)            cout<<"第"<<war->GetDays()<<"天:战争后期,双方拼死一搏"<<endl;        else        {            war->SetState(new EndState());            war->GetState();        }    }    void CurrentState(War *war) { Anaphase(war); }};//中期class MetaphaseState: public State{public:    void Metaphase(War *war) //中期的具体行为    {        if(war->GetDays() < 20)            cout<<"第"<<war->GetDays()<<"天:战争中期,进入相持阶段,双发各有损耗"<<endl;        else        {            war->SetState(new AnaphaseState());            war->GetState();        }    }    void CurrentState(War *war) { Metaphase(war); }};//前期class ProphaseState: public State{public:    void Prophase(War *war)  //前期的具体行为    {        if(war->GetDays() < 10)            cout<<"第"<<war->GetDays()<<"天:战争初期,双方你来我往,互相试探对方"<<endl;        else        {            war->SetState(new MetaphaseState());            war->GetState();        }    }    void CurrentState(War *war) { Prophase(war); }};

int main(){    War *war = new War(new ProphaseState());    for(int i = 1; i < 40;i += 5)    {        war->SetDays(i);        war->GetState();    }    delete war;    return 0;}
时间: 2024-10-06 15:06:01

c++设计模式之状态模式的相关文章

软考总结— 设计模式之状态模式

软考在即,针对下午题的设计模式,本人有觉得有必要从考试战略上稍微做一些总结.为什么呢?一方面设计模式只要掌握好做题技巧,还是比较好拿分的.另一方面,通过这次软考又进一步的学习设计模式,而且在题目中给出的设计模式都是在项目中很好的应用. 一开始做题,没有全局观.俗话说的好"不谋全局者不足谋一域",不管做什么事,先在战略方向上把握好了,采取什么样的战术,都不成什么问题了.所以考试也是一样.下面这道题就很典型:   [题目] 某大型商场内安装了多个简易的纸巾售卖机,自动出售2元钱一包的纸巾,

设计模式之状态模式

<设计模式>对状态模式的定义:允许一个对象在其状态改变时,改变它的行为.看起来对象似乎修改了它的类.别名:状态对象(Objects for State). 在下面两种情况下均可以使用State模式: 1 一个对象的行为取决于它的状态,并且他必须在运行时刻根据状态改变它的行为. 2 一个操作中含有庞大的多分枝的条件语句,并且这些分支依赖于该对象的状态.这个状态通常用一个或多个枚举常量表示.通常,有多个操作包含这一相同的条件结构.State模式将每一个条件分支放入一个独立的类中.这是得你可以根据对

JAVA设计模式之 状态模式【State Pattern】

一.概述 当系统中某个对象存在多个状态,这些状态之间可以进行转换,而且对象在不同状态下行为不相同时可以使用状态模式.状态模式将一个对象的状态从该对象中分离出来,封装到专门的状态类中,使得对象状态可以灵活变化.状态模式是一种对象行为型模式. 二.适用场景 用于解决系统中复杂对象的多种状态转换以及不同状态下行为的封装问题.简单说就是处理对象的多种状态及其相互转换. 三.UML类图 四.参与者 1>.AbstractState(抽象状态类): 在抽象状态类中定义申明了不同状态下的行为抽象方法,而由子类

大话设计模式_状态模式(Java代码)

状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变了其类. 简单描述:一个Context类(存有一个抽象状态State引用),调用状态类的方法.State的具体类方法中会判断Context类的状态(如时间),满足一个状态则执行相应动作,否则把Context的State引用指向下一个状态类,由下一个状态类决定相应行为 大话设计模式中的截图: 例子代码: Work类(Context): 1 package com.longsheng.state; 2 3 public cla

设计模式之状态模式20170712

行为型设计模式之状态模式: 一.含义 为每个状态创建与之对应的类(对应的每个类实现同一个接口或继承同一个抽象类,便于统一处理),并且再通过一个类切换状态 二.代码说明 1.一般包含三个角色抽象状态角色,具体状态角色,以及环境(上下文)角色(负责具体状态的切换). 具体步骤: 1)定义环境角色,并初始化状态 2)通过环境角色执行行为,同时也就是对应状态的行为被执行 3)对应状态的行为的执行分为两种情况: I.对应状态对应行为执行后,环境角色继续执行行为,调用的还是此状态,此状态的下一个行为(下一状

【设计模式】状态模式 改进后的

1.简单谈谈 状态模式 当一个对象的内在状态改变时允许改变其行为,这个对象看起来是改变了其类. 状态模式要解决的问题是:当控制一个对象状态转换的条件表达式过于复杂时的情况,把状态的判断逻辑转移到表示不同状态的一系列类当中,可以把复杂的判断逻辑简化. 优点:简化了一个对象的状态转换和行为改变的代码,把这部分代码放在了[状态类]中,需要注意的一点是:在[状态类]中,每个不同的[状态值]也许会被“串起来”成为一条链,这样就能保证设置不同的“离散的”[状态值]时,可以在“链上”有有个对应的处理(行为).

设计模式之状态模式(State)摘录

23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于如何创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而一个对象创建型模式将实例化委托给另一个对象.创建型模式有两个不断出现的主旋律.第一,它们都将关于该系统使用哪些具体的类的信息封装起来.第二,它们隐藏了这些类的实例是如何被创建和放在一起的.整个系统关于这些对象所知道的是由抽象类所定义的接口.因此,创建型模式在什么被创建,谁创建它,它是怎样被创建的,以

大话设计模式之----状态模式

<?php    #状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象看起来就像是改变了其类.    //抽象状态    abstract class State{        public $w;        abstract function WriteProgram($w);    }        //上午和中午工作状态类    class ForenoonState extends State{        function WriteProgram($w){     

Head First 设计模式 --10 状态模式

状态模式:允许对象在内部状态改变时改变他的行为,对象看起来好像修改了他的类. 用到的设计原则1.封装变化2.多用组合,少用继承3.针对接口编程,不针对实现编程4.松耦合5.对扩展开放,对修改关闭6.依赖抽象,而不依赖具体7.只和朋友交谈8.别找我,我会找你9.类应该只有一个修改的理由 例子来自<Head First设计模式>,糖果机的例子 interface State { public void insertQuarter(); public void ejectQuarter(); pub

【设计模式】状态模式

状态模式 在状态模式(State Pattern)中,类的行为是基于它的状态改变的.这种类型的设计模式属于行为型模式. 在状态模式中,我们创建表示各种状态的对象和一个行为随着状态对象改变而改变的 context 对象. 介绍 意图:允许对象在内部状态发生改变时改变它的行为,对象看起来好像修改了它的类. 主要解决:对象的行为依赖于它的状态(属性),并且可以根据它的状态改变而改变它的相关行为. 何时使用:代码中包含大量与对象状态有关的条件语句. 如何解决:将各种具体的状态类抽象出来. 关键代码:通常