装饰模式
2015-07-07 22:11
197 查看
装饰模式:动态给一个对象添加一些额外的职责,就像在墙上刷油漆,使用装饰模式相比生成子类达到的功能更加灵活
【场景】使用继承来实现功能的扩展,如果扩展的功能种类繁多,那么势必生成很多子类
【要点】装饰着与被装饰者拥有共同的超类,,继承的目的是继承类型,而不是行为
扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式
我们一Coffee为例子,去喝Coffee的时候往往有很多口味,原味,加牛奶,加糖的,这时候价格也不一样,但是主要的还是Coffee,其他的只是佐料,由此我们感觉到了,装饰只是扩展了外形,而本质不能变
protocol Coffe{
func getCost()-> Double
func getIngredients()-> String
}
class SimpleCoffe: Coffe {
func getCost() -> Double {
return 1.0
}
func getIngredients() -> String {
return "Coffe"
} } 我们定义了一个Protocol,所有的class均继承于此【目的是继承类型,而不是继承行为】 下面是装饰器 class CoffeDecorator: Coffe {
private var coffe:Coffe
required init( coffe:Coffe ){
self.coffe = coffe
}
func getCost() -> Double {
return self.coffe.getCost()
}
func getIngredients() -> String {
return self.coffe.getIngredients()
} } 下面我们给Coffee添加点糖 class Milk: CoffeDecorator {
required init(coffe: Coffe) {
super.init(coffe: coffe)
}
override func getCost() -> Double {
return self.coffe.getCost() + Double(2.0)
}
override func getIngredients() -> String {
return super.coffe.getIngredients()+"给加了点纯牛奶"
} } 还记得刚才的【继承的目的是继承类型,不是行为】 var simpleCoffe:Coffe? = SimpleCoffe()
println(simpleCoffe)
println("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
simpleCoffe = Milk(coffe: simpleCoffe!)
print("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
println(simpleCoffe) 琮打印我们看到装饰之后具体类型变了,但是根源没变都是Coffee【继承于统一根源,是为了同源】 装饰之后还是调用那几中方法【目的不是继承行为,因为装饰之后还是那些行为】 其实这个更多是用于添加外形,粉饰一新,盖头换面 比较典型的就是游戏角色,的装饰,武器等的扩展,绚丽的衣着
func getCost()-> Double
func getIngredients()-> String
}
class SimpleCoffe: Coffe {
func getCost() -> Double {
return 1.0
}
func getIngredients() -> String {
return "Coffe"
} } 我们定义了一个Protocol,所有的class均继承于此【目的是继承类型,而不是继承行为】 下面是装饰器 class CoffeDecorator: Coffe {
private var coffe:Coffe
required init( coffe:Coffe ){
self.coffe = coffe
}
func getCost() -> Double {
return self.coffe.getCost()
}
func getIngredients() -> String {
return self.coffe.getIngredients()
} } 下面我们给Coffee添加点糖 class Milk: CoffeDecorator {
required init(coffe: Coffe) {
super.init(coffe: coffe)
}
override func getCost() -> Double {
return self.coffe.getCost() + Double(2.0)
}
override func getIngredients() -> String {
return super.coffe.getIngredients()+"给加了点纯牛奶"
} } 还记得刚才的【继承的目的是继承类型,不是行为】 var simpleCoffe:Coffe? = SimpleCoffe()
println(simpleCoffe)
println("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
simpleCoffe = Milk(coffe: simpleCoffe!)
print("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
println(simpleCoffe) 琮打印我们看到装饰之后具体类型变了,但是根源没变都是Coffee【继承于统一根源,是为了同源】 装饰之后还是调用那几中方法【目的不是继承行为,因为装饰之后还是那些行为】 其实这个更多是用于添加外形,粉饰一新,盖头换面 比较典型的就是游戏角色,的装饰,武器等的扩展,绚丽的衣着
装饰者模式的设计原则为:对扩展开放、对修改关闭,这句话体现在我如果想扩展被装饰者类的行为,无须修改装饰者抽象类,只需继承装饰者抽象类,实现额外的一些装饰或者叫行为即可对被装饰者进行包装。所以:扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式。
相关文章推荐
- 装饰设计模式---自定义数据源
- JAVA 装饰设计模式<转载>
- js常用设计模式的实现思路,单例,工厂,代理,装饰,观察者模式!
- 设计模式——装饰模式
- 【精】适配器模式装饰模式
- Java基础-装饰设计模式、装饰与继承的区别
- 7、装饰模式(Decorator)
- IOS设计模式之二(门面模式,装饰器模式)
- 常用设计模式之装饰模式
- 装饰模式——结构型设计模式之四
- 装饰设计模式
- java设计模式---装饰模式篇
- 【大话】装饰模式与建造者模式
- php装饰模式
- 设计模式:装饰器模式(为对象动态的添加功能)
- 设计模式——单例模式、工厂模式、代理模式、观察者模式、装饰器模式
- I/O流--2(字符流,装饰设计模式)
- 设计模式讲解 — 装饰模式(1)
- 设计模式之装饰模式(Decorator)
- 装饰模式与代理模式的区别