设计模式:从聚合支付业务的设计来聊聊策略模式
六月福利
2020 年 6 月公众号码农小胖哥原创文章转发第一名将送全新《Spring Boot 实战》实体书一本,该书是学习热门框架 Spring Boot的经典之作。你不再需要依靠运气,而是勤奋。截止统计日期 2020 年 6 月 30 日,统计数据以官方公众号工具为准,运营人员不参加活动,本次活动图书由掘金社区赞助。
1. 前言
前几天大家一起学习了设计模式中的命令模式,今天来看看另一个模式。移动支付目前在国内已经是非常普及了,连楼下早餐摊的七十多岁大妈也使用支付宝和微信支付卖鸡蛋饼。如果让你做一个 App 你肯定要考虑多个渠道支付,以保证获客渠道。如果让你来接入多种支付渠道你会怎么设计?
2. 通常写法
一般下面这种写法很容易被创造出来:
public boolean pay(BigDecimal amount){boolean ret =false;if (alipay){//todo 支付宝的逻辑}else if (wechatpay){//todo 微信支付的逻辑}else if (ooxx){// ……}return ret;}
如果集成了四五种支付,这个代码就没法看了,而且改动某个支付的逻辑很容易改了其它支付的逻辑。因此需要合理的设计来避免这种风险。
3. 策略模式
大部分的支付可以简化为这个流程:
中间的发起支付前逻辑和支付后处理逻辑是客户端的自定义业务逻辑,向支付服务器发送的请求只会携带对应支付服务器特定要求的参数调用不同的支付SDK。所以我们分别建立对应支付方式的策略来隔离区分它们,降低它们的耦合度。当准备支付时我们只需要选择对应的策略就可以了。
这就用到了设计模式中的策略模式:
结合上面的类图,我们就来结合着需求来聊聊策略模式中的主要几个角色。
Strategy接口。这个接口用来声明每一种方式的独立执行策略,用来封装具体策略的特有算法逻辑。
ConcreteStrategy是Strategy的实现类。实现了不同策略的算法逻辑。比如每种支付的调用细节等等。
Context上下文。它通过策略接口来引用了具体的策略并使用具体的策略来执行逻辑,同时所有策略的共性也可以在该类中进行统一处理。在聚合支付需求中我们传入一个策略,先执行支付前的逻辑,然后使用策略,策略执行完毕后,再执行后置的共性逻辑。
Client客户端。创建策略对象并传递给上下文Context,然后由上下文运行具体的策略。
结合业务逻辑是这样的:请求到达客户端,客户端根据请求中包含的支付渠道来构建对应的策略对象并把它交给上下文对象去执行支付流程。
然后我们就可以分别为支付宝、微信支付、银联支付构造三个策略对象 AliPayStrategy
、WechatPayStrategy
、UnionPayStrategy
,我们来模拟一下执行策略:
public class Client {public static void main(String[] args) {// 获取请求中的支付渠道标识String code = "p01";PayStrategy payStrategy = null;PayRequest request = null;if (PayType.ALI.getCode().equals(code)) {//组装为支付宝支付策略payStrategy = new AliPayStrategy();// 构造支付宝请求参数request = new AliPayRequest();}if (PayType.WECHAT.getCode().equals(code)) {//组装为微信支付策略payStrategy = new AliPayStrategy();// 构造微信支付请求参数request = new WechatPayRequest();}if (PayType.UNION.getCode().equals(code)) {//组装为银联支付策略payStrategy = new UnionPayStrategy();// 构造银联支付请求参数request = new UnionPayRequest();}if (Objects.nonNull(payStrategy)) {PayContext payContext = new PayContext();payContext.setPayStrategy(payStrategy);payContext.pay(request);}}
}
我们拿到请求中的支付标识,然后初始化对应的支付策略,封装指定的请求参数,交给上下文对象PayContext
来执行请求。如果你再增加什么ApplePay之类的去实现ApplePayStrategy
就行了。
4. 优缺点
策略模式并不都带来正面的作用。
4.1 优点
我们将算法的实现和算法的使用进行了隔离,算法实现只关心算法逻辑,使用算法只关心什么条件下使用什么算法。
开闭原则,无需修改上下文对象,想扩展只需要引入新的策略。
运行时根据条件动态的去切换算法。
适应个性的同时也可以兼容共性。
4.2 缺点
客户端必须明确知道激活策略的条件。
引入太多的策略类。
可被一些函数式接口所代替。伪代码
Pay.request(data).strategy(data->{ })
。
5. 总结
策略模式也是很常见而且有着广泛使用场景的设计模式。今天我们从聚合支付来学习了策略模式,对它的优缺点也进行了一个分析。随着函数式编程的普及,策略模式开始被逐渐的代替,但是它依然值得我们去学习。感谢你的阅读,多多关注:码农小胖哥,更多编程干货奉上。老规矩DEMO关注后回复 strategy 获取。
往期推荐:
Spring Boot项目启动后如何自动执行逻辑
写着写着代码就被带上了警车
设计模式:从聚合支付业务的设计来聊聊策略模式相关推荐
- 《Head First设计模式》读书笔记 -- (第一章)策略模式
本文属贫僧不吃肉原创,欢迎转载,转载请注明来自 http://never-say-never.iteye.com/blog/851923 在开始之前,先熟悉一下OO设计的一些原则. OO设计原则之一: ...
- 『设计模式』再谈Macdonald的汉堡口味--策略模式
23种设计模式+额外常用设计模式汇总 (持续更新) 类的划分原则 面向对象的编程,并不是类越多越好,类的划分是为了封装,但分类的基础是抽象,具有相同属性和功能的对象的抽象集合才是类. 策略模式 1.定 ...
- android策略模式_Android游戏开发–设计游戏实体–策略模式
android策略模式 在这一部分中,我将尝试解释我对好的游戏设计元素的理解. 我将在示例中使用droid,并编写基本的战斗模拟器脚本以查看其行为. 问题: 我指挥一个机器人,我想消灭敌人. 再次面对 ...
- python打折简单程序每满_[Python设计模式] 第2章 商场收银软件——策略模式
题目 设计一个控制台程序, 模拟商场收银软件,根据客户购买商品的单价和数量,计算总价. 基础版本 price = float(input("输入商品单价:")) number = ...
- Java设计模式,行为型(一)(策略模式,命令模式)
策略模式(Strategy) 策略模式用来分离算法的实现,类比与if-else:通过上下文对实现进行管理. 约束接口: public interface IPay {void pay(Context ...
- 【设计模式 一】实战节日商品打折之策略模式
策略模式 定义:指对一系列的算法定义,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化. 简易UML图 需求分析 每当节假日来临,众多商品就会进行相应折扣, ...
- 精讲23种设计模式-策略模式~聚合短信服务和聚合支付服务
文章目录 一.设计模式 1. 为什么需要使用设计模式 2. 设计模式的分类 3. 什么是策略模式 4. 为什么叫做策略模式 5. 策略模式优缺点 6. 策略模式应用场景 7. Spring框架中使用的 ...
- 策略模式和工厂模式的区别_设计模式系列 — 策略模式
点赞再看,养成习惯,公众号搜一搜[一角钱技术]关注更多原创技术文章. 本文 GitHub org_hejianhui/JavaStudy 已收录,有我的系列文章. 前言 23种设计模式速记 单例(si ...
- 基于策略模式的商场价格优惠设计
基于策略模式的商场价格优惠设计 本文为个人的论文,由于一些原因未能发表,所以拿出来和朋友分享下 注:本文配有源码,如有需要的朋友,请在留言中留下邮箱地址,我会在第一时间发送 本文介绍一种基于策 ...
最新文章
- 92号油的发动机能加97吗?标号越高不代表就越好
- 中国唯一的“国际数字化转型专家”,阿里云获Forrester认可
- Masonry约束崩溃
- 企业网络运行中,您是否遇到如下问题?——Vecloud
- Anaconda3+Python3.6搭建Tensorflow
- 深度学习教程(1) | 深度学习概论(吴恩达·完整版)
- 联创宽带上网助手协议的简单分析(三):密码包的构造过程
- Java将图片压缩100KB以下,压缩图片,将几MB的图片压缩成100KB
- 《位置大数据隐私管理》—— 导读
- java队列处理高并发_Java高并发--消息队列
- 糖儿飞教你学C++ Socket网络编程——2.本书目录
- 云智慧陆兴海:统一运维体系为数字政府建设保驾护航
- 好久不见——洗尽铅华后的释然放手
- GAN(生成对抗网络)在合成时间序列数据中的应用(第二部分——利用GAN生成时间序列数据)
- Windows搭建Jenkins教程
- 机器人开发--电机中的电流环、速度环、位置环
- freemarker的第一个例子
- 编码标准-GB2312 GBK GB18030
- E2上GBA模拟器的消息
- Hessian/Burlap: is an unknown class in WebappClassLoader
热门文章
- 【FI模块学习笔记】 资本公积概述
- Ubuntu16.10拼音输入法的安装
- 什么是幸福?--林清玄
- 工业缺陷检测数据扩充论文综述
- 第二节 弹性盒子( justify-content属性、align-items属性、flex-direction属性、flex-wrap属性)
- BOE 京东方微电子研究员 专业面
- 钉钉自定义机器人配合SVN钩子事件进行消息的推送实践
- Linux电驴客户端,amule: 类似电驴(eMule)的P2P客户端
- Linux Reader单文件版,Linux Reader(查看Linux硬盘分区)
- [原创歌词]网络爱人