内容简介:很久没写文章了,今天看到了一个感觉很棒的设计模式,所以想把它记录下来,一起分享给大家。这个模式叫策略模式作为一种####应用场景:
很久没写文章了,今天看到了一个感觉很棒的设计模式,所以想把它记录下来,一起分享给大家。这个模式叫 策略模式 。 ####废话就不多说了,我们先看看它的定义:
策略模式作为一种 软件设计模式 指对象有某个行为,但是在不同的场景中,该行为有不同的实现算法。比如每个人都要“交个人所得税”,但是“在美国交个人所得税”和“在中国交个人所得税”就有不同的算税方法。 (以上是百度百科给出的定义)
####应用场景:
-
做同样的事情,但是又不同的方法当你需要通过不同的方式在代码中做同样的事情时,你就可以使用这种 设计模式 了。(最常用)
-
替代if/else 代码块 如果你觉得你的类有很多的 if/else ,这就表明这个类的职责太臃肿,可以使用这种模式来进行拆分。
####例子: 这里我举出一个例子来说明一下这个模式: 比如你有个需求,需要打印文案,打印他的大写、小写、首字母大写。可能一般的人就会这样写:
struct Logger {
enum LogStyle {
case lowercase
case uppercase
case capitalized
}
let style: LogStyle
func log(_ message: String) {
switch style {
case .lowercase:
print(message.lowercased())
case .uppercase:
print(message.uppercased())
case .capitalized:
print(message.capitalized)
}
}
}
复制代码
这样写,看起来也没啥问题,好像也很简洁是吧? 但是,这个时候,如果我让你再增加10中打印类型呢?50种呢?100种呢?你是不是要一直case100中情况?而且,所有代码都杂在一个类里面了?
那么,策略模式就可以很好的解决这个问题了。
策略模式我们有3块:
- WAHT: 定义我们要封装的操作协议。
- WHO:包含符合策略的对象的对象。
- HOW :战略的具体实施。每种实施都不同。
///WHAT
protocol LoggerStrategy {
func log(message: String)
}
///WHO
struct Logger {
let strategy:LoggerStrategy
init(_strategy:LoggerStrategy) {
strategy = _strategy
}
func log(message: String) {
strategy.log(message: message)
}
}
///HOW
struct LowercaseStrategy:LoggerStrategy {
func log(message: String) {
print(message.lowercased())
}
}
struct UppercaseStrategy:LoggerStrategy {
func log(message: String) {
print(message.uppercased())
}
}
struct CapitalizedStrategy:LoggerStrategy {
func log(message: String) {
print(message.capitalized)
}
}
///use
var logger = Logger(_strategy: CapitalizedStrategy())
logger.log(message: "my first strategy")
logger = Logger(_strategy: LowercaseStrategy())
logger.log(message: "my first strategy")
logger = Logger(_strategy: UppercaseStrategy())
logger.log(message: "my first strategy")
复制代码
结果:
这样,无论我们的需求情况如何增加,你增加100种,我们都应付,而且,代码不需要杂在一起了,而且,可扩展性也很高,需要用加用,不需要的,直接删除,增加也行。
以上所述就是小编给大家介绍的《设计模式专题-策略模式》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 设计模式——订阅模式(观察者模式)
- 设计模式-简单工厂、工厂方法模式、抽象工厂模式
- java23种设计模式-门面模式(外观模式)
- 设计模式-享元设计模式
- Java 设计模式之工厂方法模式与抽象工厂模式
- JAVA设计模式之模板方法模式和建造者模式
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
编写可读代码的艺术
Boswell, D.、Foucher, T. / 尹哲、郑秀雯 / 机械工业出版社 / 2012-7-10 / 59.00元
细节决定成败,思路清晰、言简意赅的代码让程序员一目了然;而格式凌乱、拖沓冗长的代码让程序员一头雾水。除了可以正确运行以外,优秀的代码必须具备良好的可读性,编写的代码要使其他人能在最短的时间内理解才行。本书旨在强调代码对人的友好性和可读性。 本书关注编码的细节,总结了很多提高代码可读性的小技巧,看似都微不足道,但是对于整个软件系统的开发而言,它们与宏观的架构决策、设计思想、指导原则同样重要。编......一起来看看 《编写可读代码的艺术》 这本书的介绍吧!