摘要:
这篇笔记的着重点是考虑程序的扩展性性,例如:要增加窗口时程序该如何处理、VIP窗口优先处理VIP然后可以处理快速和普通用户又该如何处理。
1.原有程序在如下情况下的处理情况
i.银行增加一类新的客户类型例如贷款客户,那么原来的程序应该作如下处理
在CustomerType的枚举中增加一个Loan的枚举值
在NumberMachine中需要添加loanManager成员变量
在ServiceWindow类中添加loanService方法且在start方法中调用该方法
ii.银行增加一个服务窗口时,源程序需要做如下处理
在mainclass的main方法中添加生成窗口的代码
ii.银行让VIP窗口在空闲的时候不仅可以处理普通用户而且还可以处理快速用户,源程序需要做如下处理
修改ServiceWindow中的vipService添加如果没有取到vip和普通用户的情况下去获取快速用户信息
2.对需求进一步的抽象
上述的需求在实际情况中应该是很常见的,我们发现一旦需求发生改变就需要修改我们的代码,说明这种实现方式的扩展性不是很好。下面是我的想法。
我觉调度的本质是:每个服务窗口可以为一些客户类型进行服务有可能是一个有可能是多个客户类型且这些客户类型存在一定的优先级。我们实际上并不关心实际的客户类型是什么因为真正实现服务的是服务窗口上的 工作人员。所以我们应将所有的客户类型看成是一样的。举个例子便于我们理解:
窗口x可以为类型a、b、c进行服务优先级a>b>c换句话说就是先服务a如果没有a用户则去取b类型的客户,如果b类型的客户还不存在则去取c类型的客户。
3.修改后程序运行逻辑
修改后的程序运行流程大概如下:
首先读取配置文件获取窗口信息和客户类型信息,根据窗口信息生成对应的窗口对象,根据类型信息生成对应的NumberManager
各个NumberManager对象根据配置信息中该类型的所占比例适时的生成客户对象,各个窗口开始服务,服务大致过程是首先获取自己的服务列表,根据服务列表去读取客户,为客户进行服务。
配置信息见下图:
<?xml version="1.0" encoding="UTF-8"?>
<types>
<type>
<type-name>VIP</type-name>
<maxTime>15</maxTime>
<minTime>7</minTime>
<type-rate>6</type-rate>
</type>
<type>
<type-name>GENERAL</type-name>
<maxTime>10</maxTime>
<minTime>5</minTime>
</type>
<type>
<type-name>QUICK</type-name>
<maxTime>5</maxTime>
<minTime>2</minTime>
<type-rate>6</type-rate>
</type>
</types>
<serverwindows>
<servicewindow>
<name>1号窗口</name>
<serverType>GENERAL</serverType>
</servicewindow>
<servicewindow>
<name>2号窗口</name>
<serverType>GENERAL</serverType>
</servicewindow>
<servicewindow>
<name>4号窗口</name>
<serverType>QUICK</serverType>
</servicewindow>
<servicewindow>
<name>5号窗口</name>
<serverType>VIP,GENERAL</serverType>
</servicewindow>
</serverwindows>
4.修改后的程序的扩展性
再来看我们要实现上述需求我们要做的事情i.银行增加一类新的客户类型例如贷款客户,那么原来的程序应该作如下处理
在配置中添加如下信息即可完成:
<type>
<type-name>LOAN</type-name>//类型名称贷款
<type-rate>2</taype-rate>//这种客户的产生比例是
<maxTime>5</maxTime>//最大处理时间
<minTime>2</minTime>最小处理时间
</type>
<servicewindow>
<name>7号贷款服务窗口</name>
<serviceType>LOAN</serviceType>
</servicewindow>
ii.银行增加一个服务窗口时,源程序需要做如下处理
在配置文件中添加窗口信息
<servicewindow>
<name>8号服务窗口</name>
<serviceType>GENERAL,VIP,QUICK</serviceType>
</servicewindow>
ii.银行让VIP窗口在空闲的时候不仅可以处理普通用户而且还可以处理快速用户,源程序需要做如下处理
修改配置文件为5号vip窗口添加服务客户的类型修改如下
<servicewindow>
<name>5号窗口</name>
<serverType>VIP,GENERAL,QUICK</serverType>
</servicewindow>
总结:
经常思考别人的实现和自己的实现,总结各种实现的优缺点这样有利于我们提高编码能力。