Software_programming_EnterpriseArch_ServiceWithSingleTonFactory

19:50:31

《UML 模式和应用》 P322

系统需要支持多种第三方外部服务,例如费用计算,授权服务,库存系统,都具有不同的API, 而且还无法改变。

解决方案之一:

使用 单例模式的工厂对象,适配提供服务

1 )  Adapter

增加一层间接性对象,通过这些对象将不同的外部接口调整为在应用程序内部使用的一致接口。

(对外部服务的适配器,专业化为 资源适配器 resoure adapter

对于选定的外部服务,将使用一个特定的适配器实例来处理。

例如 针对账务系统的 SAP, 当向外部接口发出 postSale请求时,

首先通过适配器进行转换,使其能够通过 HTTPS 上的  SOAP XML 接口来访问 SAP 在局域网上提供的 WebService。


对外服务由不同的接口,那是谁创建了这些适配器,并且如何决定创建哪种类的适配器,

如果使某个领域对象来创建这些适配器,那么领域对象的职责就超过了单纯的应用逻辑(例如销售总额的计算),并且会涉及到与外部软件

构件链接相关的其他内容。

架构设计基本原则之 : 关注分离  separation of concern ,将不同关注分离或模块化为不同领域,以确保内聚。对 GRASP 高内聚原则的应用。

领域层软件对象强调相对单纯的应用逻辑职责,另外一组对象负责关注于外部系统的连接。


2) Factory

简单工厂 (Simple Factory) 或 具体工厂 (Concrete Factory) , 不属于 设计模式, 但应用极为广泛, 也是 GoF 抽象工厂的简化。

定义纯虚构的“工厂” 对象来创建对象。 优势如下

1. 分离复杂创建对象的职责,并将其分配给内聚的帮助者对象

2.隐藏潜在的复杂创建逻辑

3.允许引入提高性能的内存管理策略,例如对象缓存或再生。

使用反射或数据驱动方法能够发现正确的类: 从外部特征文件中读取外部特征

猜你喜欢

转载自www.cnblogs.com/masterSoul/p/11443723.html