设计模式21-状态模式,State)

技术设计模式21-状态模式,State) 设计模式21-状态模式(State)如果一个实体具备状态,且在不同状态下会在同一业务场景执行不同的业务逻辑时,就可以考虑使用状态模式。设计模式21-状态模式(S

设计模式21-状态模式(州)

如果一个实体具备状态,且在不同状态下会在同一业务场景执行不同的业务逻辑时,就可以考虑使用状态模式。

设计模式21-状态模式(State)

概述

如果一个实体具备状态,且在不同状态下会在同一业务场景执行不同的业务逻辑时,就可以考虑使用状态模式。

优点

容易新加状态,封装了状态转移规则,每个状态可以被复用和共享。

避免大量的如果不是这样结构。

缺点

状态类膨胀。

新加入状态时,可能需要修改现有的状态实现。

简单实现

JDK实现

公共接口状态[

/**

*打开手机

*/

void open();

/**

*关闭手机

*/

void close();

}

@Slf4j

公共类等待状态实现了州{

私有最终MobileModel模型;

公共等待状态(移动模型){ 0

模型=模型

}

@覆盖

public void open(){ 0

log.info('开启手机中。');

this.model.setState(新的OpenState(这个。模型));

}

@覆盖

public void close(){ 0

log.info('关闭手机中。');

this.model.setState(新CloseState(此。模型));

}

}

@Slf4j

公共类OpenState实现了州{

私有最终MobileModel模型;

公共OpenState(MobileModel模型){ 0

模型=模型

}

@覆盖

public void open(){ 0

log.info('手机已开启');

}

@覆盖

public void close(){ 0

log.info('关闭手机中。');

model.setState(新CloseState(此。模型));

}

}

@Slf4j

公共类关闭状态实现了州{

私有最终MobileModel模型;

公共关闭状态(移动模式模型){ 0

模型=模型

}

@覆盖

public void open(){ 0

log.info('开启手机中。');

this.model.setState(新的OpenState(这个。模型));

}

@覆盖

public void close(){ 0

log.info('手机已关闭');

}

}

状态模式中具体实现功能的代码被封装到了状态的实现类中,上下文通过设置不同的状态实现类。

公共类MobileModel {

私人国家;

public MobileModel() { }

公共移动模型(州)

这个.状态=状态

}

公共无效设置状态(州状态){ 0

这个.状态=状态

}

public void open(){ 0

国家。open();

}

public void close(){ 0

国家。close();

}

}

在同一场景中根据不同的状态来调用不同的业务逻辑。

公共类设计模式

@测试

public void statdesignpattern(){ 0

移动模型=新移动模型();

model.setState(新的等待状态(模型));

模特。open();

模特。open();

模特。close();

模特。close();

模特。open();

}

}

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/53731.html

(0)

相关推荐

  • what引导的宾语从句,what引导的是什么从句

    技术what引导的宾语从句,what引导的是什么从句what引导名词从句(包括主语从句、宾语从句、表语从句、同位语从句)what引导的宾语从句,它在从句中可以作主语、宾语、表语、、定语、宾补。如:Whathesaidis

    生活 2021年10月27日
  • react无状态怎么写

    技术react无状态怎么写这篇文章主要介绍了react无状态怎么写,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 react无

    攻略 2021年11月26日
  • vue中len函数的功能是什么(vue中babel作用)

    技术vue中babel指的是什么意思这篇文章将为大家详细讲解有关vue中babel指的是什么意思,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 在vue中,

    攻略 2021年12月22日
  • vscode怎样引入vuejs框架

    技术vscode怎样引入vuejs框架今天就跟大家聊聊有关vscode怎样引入vuejs框架,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。vscode引入vuej

    攻略 2021年11月2日
  • wcf服务接口定义的前面需要注解啥(wcf序列化是在客户端还是服务端)

    技术WCF服务元数据结构模式是怎样的这篇文章主要介绍“WCF服务元数据结构模式是怎样的”,在日常操作中,相信很多人在WCF服务元数据结构模式是怎样的问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家

    攻略 2021年12月14日
  • SAP C4C url Mashup的跳转工作原理是什么

    技术SAP C4C url Mashup的跳转工作原理是什么这篇文章给大家介绍SAP C4C url Mashup的跳转工作原理是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一个例子:我在Sa

    攻略 2021年12月3日