状态模式---实例分析

状态模式的定义与特点

状态(State)模式的定义:对有状态的对象,把复杂的“判断逻辑”提取到不同的状态对象中,允许状态对象在其内部状态发生改变时改变其行为。
状态模式是一种对象行为型模式,其主要优点如下:

  • 结构清晰,状态模式将与特定状态相关的行为局部化到一个状态中,并且将不同状态的行为分割开来,满足“单一职责原则”。
  • 将状态转换显示化,减少对象间的相互依赖。将不同的状态引入独立的对象中会使得状态转换变得更加明确,且减少对象间的相互依赖。
  • 状态类职责明确,有利于程序的扩展。通过定义新的子类很容易地增加新的状态和转换。
    状态模式的主要缺点如下:
  • 状态模式的使用必然会增加系统的类与对象的个数。
  • 状态模式的结构与实现都较为复杂,如果使用不当会导致程序结构和代码的混乱。
  • 状态模式对开闭原则的支持并不太好,对于可以切换状态的状态模式,增加新的状态类需要修改那些负责状态转换的源码,否则无法切换到新增状态,而且修改某个状态类的行为也需要修改对应类的源码。

应用场景

某纸牌游戏软件中,人物角色具有人门级(Primary)、熟练级(Secondary),高手绍(Professional)和骨灰级(Final)四种等级,角色的等级与其积分相对应,游戏胜利将增加和分,失败则扣除积分。人门级具有最基本的游戏功能 play(),熟练级增加丁游戏胜利积分加倍功能doubleScore),高手级在熟练级基础上再增加换牌功能 changeCards(),骨灰级在高手级基础上再增加偷看他人的牌功能 peekCards()。现使用状态模式来设计该系统,绘制类图并编程实现。

所用模式结构视图

在这里插入图片描述

实现代码

context对象

public class Oyy22Player {
   
    private String name;
    private Oyy22State state;

    public String getName() {
   
        return name;
    }
    public void setName(String name) {
   
        this.name = name;
    }
    public Oyy22State getState() {
   
        return state;
    }
    public void setState(Oyy22State state) {
   
        this.state = state;
    }
    public Oyy22Player(String name) {
   
        this.name = name;
        this.state = new Oyy22PrimaryState(this);
    }
    public void play_win() {
   
        state.play_win();
    }
    public void play_lose() {
   
        state.play_lose();
    }
    public void doubleScore() {
   
        state.doubleScore();
    }
    public void changeCards() {
   
        state.changeCards();
    }
    public void peekCards() {
   
        state.peekCards();
    }
}

状态类

public abstract class Oyy22State {
   
    protected String rankName;
    protected int point;
    protected Oyy22Playe
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
设计模式是一种常用的软件设计方法,用于解决特定问题的方案。在面向对象的软件开发中,有一些经典的设计模式,其中23种是最为常见的。以下是对这23种设计模式的简要UML图解释: 1. 简单工厂模式(Simple Factory Pattern):通过一个工厂类来创建不同类型的对象。 2. 工厂方法模式(Factory Method Pattern):定义一个创建对象的接口,由子类来决定具体实例化的对象。 3. 抽象工厂模式(Abstract Factory Pattern):提供一个创建相关或依赖对象家族的接口,而无需指定具体类。 4. 单例模式(Singleton Pattern):确保一个类只有一个实例,并提供全局访问点。 5. 原型模式(Prototype Pattern):通过复制已有对象来创建新对象。 6. 建造者模式(Builder Pattern):将一个复杂对象的构建与其表示分离,使同样的构建过程可以创建不同的表示。 7. 适配器模式(Adapter Pattern):将一个类的接口转换成客户端希望的另一个接口。 8. 桥接模式(Bridge Pattern):将抽象部分与实现部分分离,使它们可以独立变化。 9. 组合模式(Composite Pattern):将对象组合成树形结构以表示"部分-整体"的层次结构。 10. 装饰器模式(Decorator Pattern):动态地给对象添加额外的职责。 11. 外观模式(Facade Pattern):为子系统中的一组接口提供一个统一的接口。 12. 享元模式(Flyweight Pattern):使用共享对象来有效地支持大量细粒度的对象。 13. 代理模式(Proxy Pattern):为其他对象提供一种代理以控制对这个对象的访问。 14. 责任链模式(Chain of Responsibility Pattern):将请求的发送者和接收者解耦,使多个对象都有机会处理这个请求。 15. 命令模式(Command Pattern):将请求封装成一个对象,并且可以用不同的请求来参数化其他对象。 16. 解释器模式(Interpreter Pattern):给定一个语言,定义它的文法的一种表示,并定义一个解释器,通过使用该解释器来解释语言中的句子。 17. 迭代器模式(Iterator Pattern):提供一种方法顺序访问一个容器对象中的各个元素,而又不暴露其内部的表示。 18. 中介者模式(Mediator Pattern):用一个中介对象来封装一系列对象之间的交互。 19. 备忘录模式(Memento Pattern):在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。 20. 观察者模式(Observer Pattern):定义了一种一对多的依赖关系,使得当一个对象改变状态时,所有依赖它的对象都会被通知并自动更新。 21. 状态模式(State Pattern):允许对象在其内部状态改变时改变它的行为。 22. 策略模式(Strategy Pattern):定义一系列的算法,将每个算法都封装起来,并使它们之间可以互换。 23. 模板方法模式(Template Method Pattern):定义一个操作中的算法的骨架,将一些步骤延迟到子类中实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值