Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >计算机体系架构-----设计模式:状态模式(从程序员加班问题切入)

计算机体系架构-----设计模式:状态模式(从程序员加班问题切入)

作者头像
阑梦清川
发布于 2025-05-09 01:15:46
发布于 2025-05-09 01:15:46
760
举报
文章被收录于专栏:学习成长指南学习成长指南
最近在学习这个专业课里面的体系结构这门课程,作为专业里面的一门基础课,这个课程里面主要讲解的就是软件的设计思想,一些历程之类的,包括了面向对象的设计方法和面向数据流的设计方法;

但是我认为更加重要的就是这个设计原则和23种常见的设计模式,设计模式不仅仅是我们考试的重点,更是我们面试的时候的考察的重点,学校老师对于这个里面的一些内容讲得效果不是很好,主要原因就是他没有读过非常著名的一本书:大话设计模式,这本书是设计模式里面的一本非常经典的这个书籍,我觉得看这本书自学的效果也比听老师讲解的这个效果很好(我们自己学校)并不是说老师讲的不好,但是听老师讲完之后感觉跟没学一样,有些老师讲课还是非常认真的;

今天我们来学习一下这个状态模式,参考的就是《大话设计模式》推荐大家去阅读以下,我这里写一下自己的思考和想法吧,主要就是按照这本书里面的第16章的思路进行书写的;

1.梦开始的地方

状态模式,看着这个名字就知道这个设计模式需要我们去处理的问题就是针对于不同的状态去进行管理,在这本书里面使用加班的问题进行相关的说明,整体的逻辑和思路非常的流畅,通过不同版本的代码修改前后的变化帮助我们的读者去进行学习这个设计模式对应的思想和具体的适用场景;

image-20250508162612650
image-20250508162612650

加班问题,主要就是针对于不同的时刻,对应着不同的状态,发生了不同的事情和问题,我们根据用户输入的不同的时刻的信息,去进行相关的内容的输出;

2.代码1.0版本

下面的这个方法就是我们的主函数里面需要调用的这个方法,writeprogram方法们主要就是针对于时间的不同区体现出来不同的工作的状态;

下面的这个代码里面的最后一个else里面又被划分为不同的情况,如果你的任务完成了,加班呢就没有事情了,但是如果你的任务没有完成,这个时候我们需要考虑加班这个时间段里面对应的这个工作的状态;

image-20250508162825875
image-20250508162825875

在我们的下面的主函数里面,主要就是针对于这个不同的时间段去调用我们的这个自定义函数,打印具体的不同时刻下面对应的这个状态的相关的信息;

image-20250508163142187
image-20250508163142187

在这本书里面显然指出来了上面的这个代码里面需要处理的问题,就是我们的代码里面的分支条件判断的语句太多了,而且上面的这个方法代码是面向过程进行编程的,没有使用我们的面向对象的这个相关思想;

下面的这个就是书本里面的两个任务的对话:程序员在教导这个小白如何使用面向对象的这个思想对于我们的上面的原来的代码进行相关的修改操作,也就是需要进行类的封装和我们的属性的定义,我们需要从加班的这个实际的场景里面去封装类,定义这个过程里面的涉及到的属性之类的;

image-20250508163323498
image-20250508163323498

3.代码2.0版本

针对于上面的类的封装和属性的定义,我们的故事的主人公对于上面的代码进行了修改,也就是我们的这个题目2.0版本的代码:

下面的这个代码里面可以明显的看到这个对应的类的封装(work这个类),里面也是包含了这个相关的过程里面需要使用到的这个属性,诸如我们的hour,也就是这个过程里面涉及到的这个时间

image-20250508163548840
image-20250508163548840

但是不可否认的就是,这个代码自定义方法里面的内容依然是过长的;在文章里面,作者是使用下面的这个例子进行相关的说明,实际上不仅如此,这个方法的定义还违反了我们的单一职责的原则,就是每一个方法里面的职责都是有限的;

但是我们的上面的代码里面,显然我们的任何时刻的任务的修改,都需要去修改这个方法,但是我们的单一职责原则是每一个方法只需要负责我们的这个过程里面的一个职责,也就是这个程序的职责太大了,违反了单一职责的原则;

image-20250508164049407
image-20250508164049407

接下来改进的方向:就是把我们的不同的状态进行分类,凸显我们的状态模式对应的这个思想;

4.代码3.0版本

下面的这个是修改之前的作者告诉我们的这个设计模式对应的好处,以及这个对应的情况;

image-20250508164517303
image-20250508164517303

下面的这个就是作者定义抽象类,并且针对于不同的类,都去实现我们的抽象类里面的这个写程序的方法,我们新增三个类去实现这个里面的方法,并且每一个类都是对应的不同的时段;

image-20250508165916494
image-20250508165916494

这个时候的工作类里面,也没有很长的这个分支判断的语句:都是对象的创建和调用这个类里面的相关的方法

image-20250508170608566
image-20250508170608566

5.梦结束的地方

这个时候,回到故事开始的这个地方,我们如果想要修改这个里面的内容,还需不需要作很大的这个修改呢,这个时候是完全不需要的,

这个时候,我们添加一个新的强制下班的状态就可以了,而且这个时候是不影响我们的其他状态里面的代码的,达到了我们的目的;

image-20250508170910671
image-20250508170910671

下面的这个就是如何进行跳转的这个示例代码:

image-20250508170723053
image-20250508170723053

)]

下面的这个就是如何进行跳转的这个示例代码:

[外链图片转存中…(img-1LieNLA5-1746699308264)]

这个就是状态模式的全部内容啦,感谢你的观看;

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-05-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
和 lvgo 一起学设计模式(二十)行为型之状态模式
我刚开始看到这个模式的时候,没啥感觉,不知道这东西要说的是个啥,后来看了个案例,渐渐清楚了,这个模式本身还是比较简单的。
星尘的一个朋友
2020/12/07
2740
和 lvgo 一起学设计模式(二十)行为型之状态模式
设计模式入门
  俗话说,好记性也不如烂笔头,最近开始阅读设计模式这方面的书籍,算是借此开个好头,把一些理解的和不太理解的都写下来。本人工作时间不长,经验、资历各方面也还比较欠缺,但目前来说还是很有决心多看一点好书,做好一些事情的。
happyJared
2018/09/20
3120
设计模式入门
程序员内功心法《设计模式》
设计模式是在软件工程实践过程中,JAVA使用者们总结出的良好的编程方法,使用设计模式能够增加系统的健壮性,易修改性和可扩展性,当你进行开发的软件规模比较大的时候,良好的设计模式会给编程带来便利,让系统更加稳定。
Java架构
2020/04/16
6850
程序员内功心法《设计模式》
设计模式初步
    最近比较闲,趁着在公司培训的间隙学习了一下设计模式,我比较喜欢的一本书是<<Head First设计模式>>,里面确实将一个个模式讲得比较透彻,采用的是Java语言编写的。最初设计模式好像是四人组GoF这本书引出的,采用的是C++语言。刚看完观察者模式,感觉OO的一些思想确实在设计模式里面得到了体现。自己现在编码还是局限于过程、基于对象的编程思维,面向对象在我的头脑中还没完全形成,这些貌似可以通过设计模式这些OO的设计原则加以实践了。
ccf19881030
2019/04/29
4590
设计模式初步
设计模式与设计原则简介(一)
对于软件开发人员, 在软件开发过程中, 面临的一般问题的解决方案就是设计模式(准确的说是OOP中)
noteless
2018/12/06
5450
设计模式与设计原则简介(一)
Java二十三种设计模式-状态模式(20/23)
本文深入探讨了状态模式,一种允许对象根据其内部状态变化而改变行为的软件设计模式。文章从定义、组成部分、实现方式、使用场景、优缺点分析、与其他模式的比较,到最佳实践和建议,全面介绍了状态模式的各个方面。通过Java语言的实现示例和实际应用案例,我们展示了状态模式如何提高代码的封装性和可扩展性,同时指出了其可能带来的系统复杂性增加和状态转换管理的挑战。最终,文章旨在帮助读者全面理解状态模式,并在适合的场景中做出明智的设计选择。
正在走向自律
2024/12/18
3500
Java二十三种设计模式-状态模式(20/23)
设计模式(-)-工厂模式介绍
>今天介绍的几个设计模式是前一段时间看《大话设计模式》这本书中介绍的,做个笔记记录下看完的前几章节的内容。不足之处欢迎指正。
用户2288853
2018/06/04
4590
知识总结:设计模式总结(C++和Python实现)前言案例实现 创建型模式 结构型模式行为型模式对比总结
前言 GoF的23种设计模式,包括创建型、结构型和行为型,其涵盖了面向对象思想的精髓以及诸多细节。本文结合《设计模式》和《大话设计模式》,并用C++和Python实现了《大话设计模式》中的23种模式案例。原文首发于个人博客Jennica.Space。 创建型 结构型 行为型 案例实现 《大话设计模式》C++版 《大话设计模式》Python版 创建型模式 工厂方法模式(Factory    Method) 工厂方法模式:定义一个用于创建对象的接口,让子类决定实例化哪个类。 工厂方法把简单工厂的内部判断逻
牛客网
2018/04/28
1.5K0
JavaScript 设计模式学习总结与感悟(开发&面试必备)
最近阅读了《JavaScript设计模式与开发实践》,收获颇丰,于是想写一点总结及感想
coder_koala
2020/07/22
5730
JavaScript 设计模式学习总结与感悟(开发&面试必备)
设计模式-6大原则
如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会消弱或者抑制这个类完成其他职责的能力。
ronixiao
2022/07/25
4960
设计模式 ☞ 行为型之状态模式
  状态(State)模式的定义:对有状态的对象,把复杂的“判断逻辑”提取到不同的状态对象中,允许状态对象在其内部状态发生改变时改变其行为。在软件开发过程中,应用程序中的部分对象可能会根据不同的情况做出不同的行为,我们把这种对象称为有状态的对象,而把影响对象行为的一个或多个动态变化的属性称为状态。当有状态的对象与外部事件产生互动时,其内部状态就会发生改变,从而使其行为也发生改变。如人都有高兴和伤心的时候,不同的情绪有不同的行为,当然外界也会影响其情绪变化。   状态模式的解决思想是:当控制一个对象状态转换的条件表达式过于复杂时,把相关“判断逻辑”提取出来,用各个不同的类进行表示,系统处于哪种情况,直接使用相应的状态类对象进行处理,这样能把原来复杂的逻辑判断简单化,消除了 if-else、switch-case 等冗余语句,代码更有层次性,并且具备良好的扩展力。
Demo_Null
2021/01/18
3610
设计模式-状态模式
晚上睡觉前,需要关灯睡觉。一关一开,类似状态模式的,而开关主要是用来切换所需要的状态,由于不同的状态产生不同的结果。
逍遥壮士
2020/09/18
5630
设计模式-状态模式
"设计模式我学过呀,就是没用过"
在开发中,不使用设计模式也不是不可以,但是用好设计模式能帮忙我们更好的去解决实际问题。
田维常
2021/04/22
3440
"设计模式我学过呀,就是没用过"
设计模式系列,六大设计原则
设计模式和性能优化有没有关系?最近,我看到有人再讲性能优化的时候,讲到了“有些设计模式可以做到一定程度的性能优化”。
业余草
2019/08/14
8250
设计模式之总述
因软件是不停迭代的,故代码需不停堆砌,原设计会存在一些问题,解决办法就是代码重构。
CoreDao
2021/04/13
4430
设计模式(总纲)
网上关于设计模式的文章很多,为什么我还要重复写设计模式的文章,在看到LZ大牛的一篇《聊聊阿里社招面试,谈谈“野生”Java程序员学习的道路》博文后,发现自己陷入了思维误区,在之前看的一本《Java EE设计模式解析与指南》本中,提出一个反设计模式的思维,于是自己便成了这个思维的拥护者(还是懒)
tanoak
2018/08/02
2860
JAVA 设计模式 状态模式
本文介绍了JAVA设计模式中的状态模式,该模式用于当一个对象的内在状态改变时允许改变其行为,属于行为型模式。结构包括状态模式结构图和状态模式代码实现。
静默虚空
2018/01/05
7660
JAVA 设计模式 状态模式
[C++设计模式] 为什么需要设计模式?
设计模式(Design Pattern)是对软件开发过程中反复出现的设计问题所提供的通用解决方案。它不是代码,而是经过验证的“最佳实践”,以一种结构化的方式记录了解决问题的思想。
DevKevin
2024/12/04
1420
[C++设计模式] 为什么需要设计模式?
[设计模式]之一:简单工厂模式
最近思考了一下这两年的工作:做Android的时候一直看Android知识,做iOS的时候一直学iOS的东西。其实看起来感觉这样没什么问题,但仔细想想,我发现自己一直忽略了一大片知识点,那就是软件工程。不同的语言,不同的开发方向的确在代码上有千差万别,但是回到软件架构上来看,所有的编程思想都是相通的,比如说算法,再比如说设计模式。算法这点可能在移动开发中用得较少,但设计模式是必不可少的。我回想了一下,虽说写了不少代码,也考虑过一些关于模块代码结构的设计,但还是缺乏对这一块的系统了解。所以就找了一本众人推荐的书——《大话设计模式》来看。这本书写的的确好,通俗易懂,所以在这里我也推荐一下。这本书看了几个章节我就有一种受人点拨的感觉,明显感觉到如果我把这本书吃透,编码水平肯定能提高一个level。想到我的读书列表还有几本受到程序员追捧的大作要看,突然有种迫不及待就要一本一本读下去的感觉。不过读书可不是读一遍就完事的,关键就在于悟。进步也不能急,一点一点来吧。加油!
wOw
2018/09/18
5380
[设计模式]之一:简单工厂模式
一文带你读懂:设计模式的六大原则
软件设计最大的难题就是应对需求的变化,但是纷繁复杂的需求变化又是不可预料的,我们要为不可预料的变化做好准备,这本身是一件非常痛苦的事情,但好在有大师们已经给我们提出了非常好的六大设计原则和23种设计模式来“封装”未来的变化。
后台技术汇
2022/05/28
9740
一文带你读懂:设计模式的六大原则
推荐阅读
相关推荐
和 lvgo 一起学设计模式(二十)行为型之状态模式
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档