【设计模式-状态模式】
时间:2022-07-24
本文章向大家介绍【设计模式-状态模式】,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
【导读】人在不同的状态下会做出不同的行为,比如愤怒的时候会做一些出格的事,高兴的时候会分享快乐,这种就是状态模式。
一、定义
允许一个对象在其内部状态发生改变时,改变其行为。
二、实例
比如视频有几种状态,播放、暂停、加速三个状态,视频在暂停状态的时候不能进行加速。
抽象视频状态对象:
public abstract class VideoState {
1、包含一个视频上下文,是记录当前视频处于何种状态的
protected VideoContext videoContext;
public void setVideoContext(VideoContext videoContext) {
this.videoContext = videoContext;
}
2、播放
public abstract void play();
3、加速
public abstract void speed();
4、暂停
public abstract void pause();
}
播放状态:
public class PlayState extends VideoState {
@Override
public void play() {
System.out.println("视屏处于播放状态");
}
@Override
public void speed() {
1、如果播放中需要加速,则将视频转成播放状态
super.videoContext.setVideoState(VideoContext.SPEED_STATE);
}
@Override
public void pause() {
2、如果播放中需要暂停,则将视频转成状态状态
super.videoContext.setVideoState(VideoContext.PAUSE_STATE);
}
}
加速状态:
public class SpeedState extends VideoState {
@Override
public void play() {
super.videoContext.setVideoState(VideoContext.PLAY_STATE);
}
@Override
public void speed() {
System.out.println("视屏处于加速状态");
}
@Override
public void pause() {
super.videoContext.setVideoState(VideoContext.PAUSE_STATE);
}
}
暂停状态:
public class PauseState extends VideoState {
@Override
public void play() {
super.videoContext.setVideoState(VideoContext.PLAY_STATE);
}
@Override
public void speed() {
throw new RuntimeException("暂停状态下不能加速");
}
@Override
public void pause() {
System.out.println("视屏处于暂停状态");
}
}
视频上下文,记录视频当前处于何种状态:
public class VideoContext {
private VideoState videoState;
public final static PlayState PLAY_STATE = new PlayState();
public final static SpeedState SPEED_STATE = new SpeedState();
public final static PauseState PAUSE_STATE = new PauseState();
public void setVideoState(VideoState videoState) {
this.videoState = videoState;
this.videoState.setVideoContext(this);
}
public VideoState getVideoState() {
return videoState;
}
public void play(){
this.videoState.play();
}
public void pause(){
this.videoState.pause();
}
public void speed(){
this.videoState.speed();
}
}
测试类:
类图:
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 【Java面试总结】多线程
- RL实践1——动态规划值迭代
- RL实践3——为Agent添加Policy
- CentOS 快速安装Python3和pip3
- Linux使用 常见经验和技巧总结
- SwiftUI:辅助功能——简单介绍
- Xshell突出显示集
- samba服务安装脚本
- 【Vue.js】Vue.js组件库Element中的树形控件、分页、标记、头像和警告
- 磁盘分区空间检测工具
- 【Vue.js】Vue.js组件库Element中的加载、消息提示、弹框和通知
- 云主机装ikuai
- 【Vue.js】Vue.js组件库Element中的导航菜单、标签页、面包屑和页头
- CentOS7查看硬盘是SSD还是HDD
- 浅谈CentOS防火墙命令