博客
关于我
VB.NET & 职责链模式 (下机时间操作)
阅读量:108 次
发布时间:2019-02-26

本文共 1279 字,大约阅读时间需要 4 分钟。

设计模式是软件开发中的常用方法,帮助开发者解决常见问题。在机房收费系统的重构过程中,可以发现职责链模式在处理多个对象之间的请求时非常有用。以下是职责链模式的详细解析。

定义

职责链模式允许多个对象处理请求,从而避免请求的发送者和接受者之间的耦合关系。通过将对象连成一条链,并沿着这条链传递请求,直到有一个对象处理完成。

例子

在机房收费系统中,上机时间的计算分为三个部分:准备时间、至少上机时间和单位递增时间。这种分段性不禁让人联想到职责链模式。具体来说,可以将三个时间类型分别作为三个处理类,通过职责链的方式将请求传递下去。

代码实现

  • 抽象类:定义一个处理请求的接口。
  • Public MustInherit Class BL_TimeHandler    Protected calculate As BL_TimeHandler    Public Sub Setcalculate(ByVal calculate As BL_TimeHandler)        Me.calculate = calculate    End Sub    Public MustOverride Function HandleTime(ByVal time As Integer) As IntegerEnd Class
    1. 子类实现
      • 准备时间处理类:如果上机时间小于准备时间,返回0,否则传递请求。
      • 至少上机时间处理类:如果上机时间小于等于至少时间,返回至少时间,否则传递请求。
      • 单位递增时间处理类:根据递增时间计算实际消费时间。

      调用流程

      在U层中,通过构造职责链对象并传递请求,计算上机时间。具体实现如下:

      Dim enline As New Entity.LineEntityWith enline    .Ondate = lineRe(0).Ondate    .Ontime = lineRe(0).Ontime    .Offdate = CStr(Format(Now(), "yyyy-MM-dd"))    .Offtime = CStr(Format(Now(), "HH:mm:ss"))End WithDim basicdataList As IList(Of Entity.BasicDataEntity)Dim BLLBasicdata As BasicDataBLL = New BasicDataBLL()Dim enbasicdata As New Entity.BasicDataEntitybasicdataList = BLLBasicdata.ReadBasic(enbasicdata)enline.consumeTime = onTimeCount.CostTime(basicdataList, enline)

      分类

      职责链模式分为纯职责链和不纯职责链两种类型。不纯职责链允许处理者部分处理后继续传递请求,请求可以最终由一个处理者完成或不被处理。

      通过以上分析,可以清晰地看到职责链模式在机房收费系统中的实际应用。

    转载地址:http://nwtk.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0020---Selectionkey在NIO体系
    查看>>
    Vue踩坑笔记 - 关于vue静态资源引入的问题
    查看>>
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0057---Netty群聊系统服务端
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty工作笔记0085---TCP粘包拆包内容梳理
    查看>>
    Netty常用组件一
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty心跳检测机制
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架内的宝藏:ByteBuf
    查看>>