swift设计模式学习 - 策略模式
移动端访问不佳,请访问我的个人博客
策略模式策略模式定义了算法家族,分别封装起来,让它们之间可以相互替换,此模式让算法的变化,不会影响到使用算法的客户。 策略模式的组成
策略模式的基本实现上图是最基本的装饰模式的结构图,下面将用Swift代码来实现一个基本策略模式: // 策略类,定义所有支持 的算法的公共接口
protocol Strategy {
func AlgorithmInterface()
}
// 具体策略类,封装了具体的算法或行为,继承于Strategy
class ConcreteStrategyA: Strategy {
func AlgorithmInterface() {
print("ConcreteStrategyA")
}
}
class ConcreteStrategyB: Strategy {
func AlgorithmInterface() {
print("ConcreteStrategyB")
}
}
class ConcreteStrategyC: Strategy {
func AlgorithmInterface() {
print("ConcreteStrategyC")
}
}
// Context上下文,用一个 ConcreteStrategy来配置,维护一个对Strategy对象的引用
class Context {
var strategy: Strategy?
func ContextInterface() {
strategy?.AlgorithmInterface()
}
}
以上代码是最简单的策略模式的实现过程,定义了一个 用策略模式解决实际问题(商场打折)我们知道在商场中一般有很多打折优惠方案,类似这种问题就可以用策略模式来解决,打折不同的方案就相当于不同的策略( 以上是一个简单的商场收银系统, import Foundation
// 定义一个收费的策略接口
protocol CashSuper {
func acceptCash(money: Double) -> Double
}
// 普通收费子类
class CashNormal: CashSuper {
// 正常原价返回
func acceptCash(money: Double) -> Double {
return money
}
}
// 打折收费子类
class CashRebate: CashSuper {
// 折扣率
private var moneyRebate: Double = 1.0
init(moneyRebate: Double) {
self.moneyRebate = moneyRebate
}
func acceptCash(money: Double) -> Double {
return money*moneyRebate
}
}
// 返利收费子类
class CashReturn: CashSuper {
// 返利要求
private var moneyCondition: Double = 0
// 返多少
private var moneyReturn: Double = 0
init(moneyCondition: Double,moneyReturn: Double) {
self.moneyCondition = moneyCondition
self.moneyReturn = moneyReturn
}
func acceptCash(money: Double) -> Double {
var result = money
if money >= moneyCondition {
result = money - floor(money / moneyCondition) * moneyReturn
}
return result
}
}
// context类
class CashContext {
private var cs: CashSuper?
// 通过枚举判断使用哪种方式
init(style: CashStyle) {
switch style {
case .normal:
cs = CashNormal()
case .rebate(moneyRebate: let money):
cs = CashRebate(moneyRebate: money)
case .return(moneyCondition: let moneyCondition,moneyReturn: let moneyReturn):
cs = CashReturn(moneyCondition: moneyCondition,moneyReturn: moneyReturn)
}
}
func getResult(money: Double) -> Double {
return cs?.acceptCash(money: money) ?? 0
}
}
// 优惠的枚举类型
enum CashStyle {
case normal
case rebate(moneyRebate: Double)
case `return`(moneyCondition: Double,moneyReturn: Double)
}
下面我们测试一下代码: let money: Double = 300
// 普通
let normal = CashContext(style: .normal)
// 打7折
let rebate = CashContext(style: .rebate(moneyRebate: 0.7))
// 满一百返20
let `return` = CashContext(style: .return(moneyCondition: 100,moneyReturn: 20))
print("普通: (normal.getResult(money: money))")
print("打7折: (rebate.getResult(money: money))")
print("满一百返20: (`return`.getResult(money: money))")
下面是执行的结果: 普通: 300.0 打7折: 210.0 满一百返20: 240.0 策略模式总结我们可以理解为策略就是用来封装算法,但在实践过程中不用那么死板,可以用来封装几乎任何类型的规则,只要在分析过程中听到需要在不同时间应用不同的业务规则,就可以考虑使用策略模式处理这种变化的可能性。
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- dart – Flutter在`flutter`命令失败
- ruby – Sinatra全局应用程序变量
- vue-cli脚手架build目录下utils.js工具配置文件详
- 12、基于XML方式的AOP
- android – 用C/C++代码构建Flutter – 例子?
- cocos2d-x, protobuf, no config.h, #error "No
- c# – 如何将nullable int转换为可空的short?
- 【swift_3】swift之UITableView和UINavigation视
- 讲解C++的do while循环和循环语句的嵌套使用方法
- ruby-on-rails – 你应该需要’minitest / autor