设计模式“乱用”记录
自从拜读完阎宏的《Java与模式》后,即开始进入到第一步“乱用”境界,在此留下脚印。
?
Builder
1) 创建业务操作日志对象
背景:设计开发一个适用于采用SSH结构开发的应用系统的通用操作日志模块。使用原因简述:由于该对象的部分属性值(如操作对象、操作内容、操作前值、操作后值等)的产生根据业务的不同会发生变化,同时这些属性的生产顺序存在着一定先后关系。模式角色对应:Builder定义生成与操作日志PO属性对应的方法接口以及返回PO的方法接口Concrete BuilderBuilder定义的方法实现Director负责按一定顺序调用Builder中的方法Product操作日志PO2) 创建Excel对象
背景:编写Web页面列表数据导出到Excel文件的工具类(基于poi组件)。使用原因简述:一个Excel表格通常可分为表头、表数据、统计行这3部分,一般来说在导出成为Excel格式时也会按这3步进行,且顺序也是有所讲究。模式角色对应:Builder定义生成表头、表数据、统计行的方法接口以及返回对象的方法接口Concrete BuilderBuilder定义的方法实现Director负责按表头、表数据、统计行的顺序调用Builder中的方法ProductHSSFWorkbook对象Chain of Responsibility
1) 另见:? commons-chain 应用记录
?
Command
1) 消息接口服务端
背景:需要接收来自3种客户端发来的消息,并进行分发处理。使用原因简述:每个消息接口最终的处理是一致,在接收后、处理前根据不同种类的客户端可能还有一些额外处理。模式角色对应:Client3种客户端Command消息接口ConcreteCommandCommand定义的方法实现,分别对应各个具体消息接口的实现Invoker3个调用者,分别对应3种客户端Receiver消息的统一接收终端
Strategy
1) 解析文本文件,得到业务对象 / 将业务对象的属性值转换成文本
背景:客户端与服务端通过文本文件交互数据。使用原因简述:文本文件的内容格式有xml和按行这2种,这2种格式所对应的解析/生成方法不同。模式角色对应:Context具有Strategy属性、外部调用其得到结果Strategy要得到的结果的方法接口ConcreteStrategyStrategy定义的方法实现,分别有2个具体实现类对应2种情形2) 生成业务操作日志对象的各个属性值
背景:设计开发一个适用于采用SSH结构开发的应用系统的通用操作日志模块。使用原因简述:由于系统是基于SSH开发的,操作日志功能的加入是采用AOP方式实现的,触发操作日志记录主要有以下2种情形:1是通过struts的action触发;2是通过其他方式(如webservice接口等),不同情形下生成各个具体属性值的实现方法不同。模式角色对应: Context具有Strategy属性、外部调用其得到结果Strategy要得到的结果的方法接口ConcreteStrategyStrategy定义的方法实现,分别有2个具体实现类对应2种情形Proxy
1) 调用解析文本文件方法之前的处理
背景:在调用解析方式之前需要一些额外处理(如判断待解析的内容是否为null等)。使用原因简述:通过这种结构解耦具体解析方法及其调用。模式角色对应:Subject解析方法接口RealSubject具体解析方式调用过程ProxySubject持有RealSubject引用,在具体解析方式调用过程之前,进行一些额外处理
2) 修改原有业务接口的具体实现(增加一些业务校验等)
背景:原先实现不够完善,现在需要增加一些业务校验。使用原因简述:已有的实现本身并没有太多问题,只是需要在其之前加些处理,通过这种结构避免修改已有代码。模式角色对应:Subject业务接口方法RealSubject原有的业务接口方法具体实现类ProxySubject持有RealSubject引用,调用原有的业务接口实现前的处理均在此实现。
3) 与2)类似。
?
在进行完善性维护时较为常用该模式。