【C#重构】——上机余额判断应用的 状态模式

2023-12-27 12:20

本文主要是介绍【C#重构】——上机余额判断应用的 状态模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

回顾状态模式:

在这里插入图片描述
根据不断的请求或者实时变化,更改状态
可对状态进行读取并更具判断,设置新的状态
不同的子状态重写抽象类状态,进行实时判断更改。

实战分析:

在上机中,要进行实时地余额判断,并进行余额不足和小于最低余额强制下机的操作
或许实时的余额变化,进行判断余额调整状态。
Sate类

public class StateModel{public abstract class State{public abstract string WriteProgram(Context context);}public class Context{//用到的实体private State current;private double consume;public double Consume { get => consume; set => consume = value; }public State Current { get => current; set => current = value; }public void SetState(State s)//改变初始状态,可读当前状态{Current = s;}public string WriteProgram()//请求的处理,并设置下一个状态{string a = Current.WriteProgram(this);return a;}public class StateOne : State//具体子状态1{public override string WriteProgram(Context context){string a = "null";if (context.Consume >= 10){a = "null";}else{context.SetState(new StateTwo());context.WriteProgram();}return a;}}public class StateTwo : State//具体子状态2{public override string WriteProgram(Context context){string a = "null";if (context.Consume < 10){a = "余额不足10元,请尽快充值,以免影响上机!";}else{context.SetState(new StateThree()); context.WriteProgram();}return a;}}public class StateThree : State//具体子状态3{public override string WriteProgram(Context context){string a = "null";if (context.Consume < 5){a = "余额不足5元,正在下机";}return a;}}}

外观层进行传值

//连接状态模式public string InquireyStat(LineInfo outline){StateModel.Context cs = new StateModel.Context();cs.Consume = outline.Cash;string a = cs.WriteProgram();Entity.Gloable.Time++;return a;}

UI层判断

 private void txtOnUserID_EnabledChanged(object sender, EventArgs e){if (txtOnUserID.Enabled == false)//当确定用户已上机,则启动状态模式,实时判断余额情况{timerOut.Enabled = true;//计时器开始运行timerOut.Start();//启动计时器          }}private void timerOut_Tick(object sender, EventArgs e){//student 表 selectEntity.StudentInfo student = new Entity.StudentInfo();student.UserID = Convert.ToInt32(txtOutUserID.Text.Trim());DataTable table1;Facade.OutLineFacade facade = new Facade.OutLineFacade();table1 = facade.SelectStudentFacade(student);//line_info表,插入上下机记录表 insertEntity.LineInfo outline = new Entity.LineInfo();int balance = Convert.ToInt32(table1.Rows[0][2].ToString());//学生表余额outline.Consume_time = Convert.ToString(Gloable.Time);//??//每一小时查看余额string a = facade.InquireyStat(outline);if (a == "null"){return;}else{MessageBox.Show(a, "提示");if (a == "余额不足5元,下机"){//调用下事件btnOutLogin_Click(sender, e);timerOut.Start();}}}

还有不完善的地方,多指正

这篇关于【C#重构】——上机余额判断应用的 状态模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/543109

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount