-
问题一: 需要根据平台来选择不同的接口。但是底层的接口并不支持多态的实现。
例子:根据goodsId拉取线上商品 淘宝的接口是TbInfoAcquireService.itemDetailGet(List<String> goodsIds, Long channelNo, Long brandsNo, Long userId)
那么一号店的接口可能是
YhdService.itemGet(List<String> goodsIds, Long channelNo, Long brandsNo);
这样子就无法在代码中实现多态的性质。如果要直接写的话,就必须写成
switch ** case: TbInfoAcquireService.itemDetailGet case: YhdService.itemGet
目前的解决方案有2种:
* 1.中间做一层代理类。 TbProxy.itemGet(List<String> goodsIds, Long channelNo, Long brandsNo, Long userId) implements Proxy; YhdProxy.itemGet(List<String> goodsIds, Long channelNo, Long brandsNo, Long userId) implements Proxy; 这样子就能直接在代码中实现多态的性质。 * 2.直接去修改原代码使原本提供的接口就有多态的性质。可以增加一个接口 interface ItemGet.itemGet(List<String> goodsIds, Long channelNo, Long brandsNo, Long userId) 然后`TbInfoAcquireService`和`YhdService`就可以去继承这个`interface`。或者让实现类去实现2个接口。
问题二:我们按照类的执能细分了很多类。
当Action
需要调用这些Service
的时候。处理方法有2种。
一种是,直接调用这些Service
。
第二种是。写一个总的service
然后在这个service
中做一层代理,来分别调用其他的service
.
这样就会出现一个问题。Action A
依赖Service B,Service C
。同时Service C
是依赖Service B
的。不得不说这样子的设计肯定是有点问题的。具体的改进方式希望自己能够在日后的工作中能够总结出来。
相关文章
- 基于SpringBoot+Vue的企业安全评估系统设计与实现(源码+lw+远程部署)
- Word2Vec在Tensorflow上的版本以及与Gensim之间的运行对比
- GNU μC/OS-II 在 S3C2440 上中断的实现
- Ubuntu上安装多个不同版本的CUDA
- 瓜子IM智能客服系统的数据架构设计(整理自现场演讲)
- 基于UML的公开招聘教师管理系统建模的研究和设计
- 拖拽碰撞--原声js(自身理解上新的方法)
- 100个节点的部署,整合Docker、Kubernetes和Jenkins的详细设计
- SQL Server 2014里的针对基数估计的新设计(New Design for Cardinality Estimation)
- 在Ubuntu 18.04上安装Linux、Nginx、MySQL、PHP(LEMP堆栈)的方法