【机房重构】——策略模式+简单工厂计算消费

简介: 【机房重构】——策略模式+简单工厂计算消费

引言


在计划上机功能模块的时候,计算消费金额是一个不容忽视的问题,这关系着消费者利益,我们都清楚和消费者打交道的功能一定要做活,因为我们为了促进消费会经常做些促销活动,这时候就需要我们的系统在计算消费金额的时候能很好的适应这用需求的变更,当我想到这些的时候,小菜和大鸟商讨关于商场促销的画面就浮现在脑海中,所以,我也打算在计算消费的时候,采用策略模式,下面和大家一起分享一下我的想法:


理论部分


策略模式:它定义了算法家族,分别封装起来,让他们之间可以相互替换,此模式让算法的变化,不会影响到使用算法的用户。


类图


20150109195525926.png

优点:1、它定义了一系列的算法的方法,所有这些算法完成的都是相同的工作,只是实现不同,他可以以相同的方式调用所有的算法,减少了各种算法类与使用算法类之间的耦合。


2、在Strategy类层次为Context定义了一系列的可供重用的算法或行为,继承有助于析取出这些算法中的公共功能。


3、简化了单元测试,每个算法都有自己的类,可以通过自己的接口单独测试。

应用:策略模式并不是只是用来封装算法和算法打交道的,在实践中可以用它来封装几乎任何类型的规则,只要在不同的时间应用不同的业务规则,我们就可以考虑用策略模式类处理这种变化的可能性。


实践部分


介绍了一些关于策略模式的基本知识,下面就结合自己在机房重构的时候在计算上机消费的时候对策略模式的应用。


简单类图:

20150109203336509.jpg

参考代码:

'**********************************************
'说明:计算消费金额的抽象类
'命名空间:BLL
'机器名称:晓
'创建日期:2015/1/8 20:01:18
'作者:郑浩
'版本号:V1.00
'**********************************************
Public MustInherit Class CashSuper
    Public MustOverride Function AcceptCash(ByVal basicdata As Entity.EN_BasicData, ByVal consumetime As Integer) As Double
End Class
Imports BLL.CashSuper
''' <summary>
''' 临时用户计算消费时间
''' </summary>
''' <remarks></remarks>
Public Class CTempUser : Inherits BLL.CashSuper
    Public Overloads Overrides Function AcceptCash(basicdata As Entity.EN_BasicData, consumetime As Integer) As Double
        Return basicdata.TempPrice * (consumetime / 60)
    End Function
End Class
Imports BLL.CashSuper
''' <summary>
''' 固定用户的消费金额的计算
''' </summary>
''' <remarks></remarks>
Public Class FixUser : Inherits BLL.CashSuper
    Public Overloads Overrides Function AcceptCash(basicdata As Entity.EN_BasicData, consumetime As Integer) As Double
        Return basicdata.FixPrice * (consumetime / 60)
    End Function
Public Class CashFactory
    ''' <summary>
    ''' 消费金额计算工厂
    ''' </summary>
    ''' <param name="type"></param>
    ''' <returns></returns>
    ''' <remarks></remarks>
    Public Function CreateCashAccept(ByVal type As String) As BLL.CashSuper
        Dim cs As BLL.CashSuper
        cs = Nothing
        Select Case type
            Case "临时用户"
                cs = New BLL.CTempUser()
            Case "固定用户"
                cs = New FixUser()
        End Select
        Return cs
    End Function
End Class

以上这些简单的代码是在B层完成的,当我们完成这些以后,只需要在在调用的时候,传给相应的参数就可以了,这样当我们需要别的计费的方式的时候,会很容易扩展,很好满足了开放封闭原则。


小结


在设计模式中策略模式是比较简单的一个,所以代码相比较简单,但是这个策略模式和简单工厂模式相结合真的给我们带了很大便利,因为我们机房这个系统还是相对比较小的,所以一些模式的功能不能很好的体现,但是我们需要根据它的需求来想象一个大的系统,这样我们就会有加入设计模式的冲动,设计模式需要我们在实践中不断地摸索,才能领略它的魅力,所以在重构的时候尽可能的使用一些设计模式。

目录
相关文章
|
设计模式 算法 Java
JAVA设计模式13:模版方法模式,将一些步骤延迟到子类中实现
JAVA设计模式13:模版方法模式,将一些步骤延迟到子类中实现
|
设计模式 缓存 算法
JAVA设计模式14:策略模式,使算法的变化独立于使用它的客户端
JAVA设计模式14:策略模式,使算法的变化独立于使用它的客户端
104 0
|
1月前
|
设计模式 监控 算法
Java设计模式梳理:行为型模式(策略,观察者等)
本文详细介绍了Java设计模式中的行为型模式,包括策略模式、观察者模式、责任链模式、模板方法模式和状态模式。通过具体示例代码,深入浅出地讲解了每种模式的应用场景与实现方式。例如,策略模式通过定义一系列算法让客户端在运行时选择所需算法;观察者模式则让多个观察者对象同时监听某一个主题对象,实现松耦合的消息传递机制。此外,还探讨了这些模式与实际开发中的联系,帮助读者更好地理解和应用设计模式,提升代码质量。
Java设计模式梳理:行为型模式(策略,观察者等)
|
4月前
|
设计模式 Ruby Python
Python实现工厂模式、抽象工厂怎么做?
**Python中的工厂模式**是设计模式的一种,用于灵活地创建对象。可以使用函数或类来实现。例如,一个简单的工厂函数创建`Product`对象
|
5月前
|
Java
揭秘Java多态:为何同一消息,对象们却各有“心思”?
【6月更文挑战第17天】Java中的多态性让不同对象对同一方法有独特响应。以动物园为例,抽象类`Animal`定义`makeSound()`,子类如`Tiger`, `Lion`, `Monkey`继承并重写该方法。通过`Animal`引用调用,实际执行子类实现,展示动态绑定的威力。多态提升代码灵活性,支持扩展而无需改动原有代码,体现面向对象的核心思想。
28 2
|
算法
使用工厂模式、策略模式、门面模式、单例模式、责任链模式、装饰者模式和访问者模式来实现红包雨(二)
使用工厂模式、策略模式、门面模式、单例模式、责任链模式、装饰者模式和访问者模式来实现红包雨
|
设计模式 算法
使用工厂模式、策略模式、门面模式、单例模式、责任链模式、装饰者模式和访问者模式来实现红包雨(一)
使用工厂模式、策略模式、门面模式、单例模式、责任链模式、装饰者模式和访问者模式来实现红包雨
|
6月前
|
算法
犯错总结--工厂模式和策略模式傻傻没分清
犯错总结--工厂模式和策略模式傻傻没分清
61 0
犯错总结--工厂模式和策略模式傻傻没分清
|
设计模式 人工智能 前端开发
彻底说透简单工厂那些你没有关注过的细节
接下来看代码,还是以创建一门网络课程为例。假设有Java架构、大数据、人工智能等课程,已经形成了一个生态。我们可以定义一个课程标准ICourse接口。
68 0
|
设计模式 数据安全/隐私保护
这才是责任链模式的优雅使用方式
首先创建一个实体类Member。
108 0