装饰模式:动态给一个对象添加一些额外的职责,就像在墙上刷油漆,使用装饰模式相比生成子类达到的功能更加灵活
【场景】使用继承来实现功能的扩展,如果扩展的功能种类繁多,那么势必生成很多子类
【要点】装饰着与被装饰者拥有共同的超类,,继承的目的是继承类型,而不是行为
扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式
我们一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"
}
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()
}
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()+"给加了点纯牛奶"
}
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)
println("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
simpleCoffe = Milk(coffe: simpleCoffe!)
print("\(simpleCoffe!.getCost()) \( simpleCoffe!.getIngredients() )")
println(simpleCoffe)
琮打印我们看到装饰之后具体类型变了,但是根源没变都是Coffee【继承于统一根源,是为了同源】
装饰之后还是调用那几中方法【目的不是继承行为,因为装饰之后还是那些行为】
其实这个更多是用于添加外形,粉饰一新,盖头换面
比较典型的就是游戏角色,的装饰,武器等的扩展,绚丽的衣着
装饰者模式的设计原则为:对扩展开放、对修改关闭,这句话体现在我如果想扩展被装饰者类的行为,无须修改装饰者抽象类,只需继承装饰者抽象类,实现额外的一些装饰或者叫行为即可对被装饰者进行包装。所以:扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式。
相关推荐
装饰模式是Erich Gamma等人所著的《设计模式:可利用面向对象软件的基础》一书中众多模式之一。一般来说,此模式在设计Swing的程序员中比较流行,他们用它来改进软件。今天,即使有许多程序是基于Web应用的,装饰...
java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式java设计模式之装饰模式
设计模式 c# 装饰模式
装饰模式.doc 装饰模式.doc 装饰模式.doc
C++23种设计模式之 装饰模式。:当你向旧的类中添加新代码时,一般是为了添加核心职责或主要行为。而当需 要加入的仅仅是一些特定情况下才会执行的特定的功能时(简单点就是不是核心应用的功 能),就会增加类的...
装饰模式的一个简单实例,小猪吃苹果的游戏,每吃一种苹果,增加一种不同的功能。装饰模式是在不必改变原类文件和使用继承的情况下,动态的扩展一个对象的功能。
JAVA设计模式之装饰模式代码
装饰模式: 装饰模式是为已有功能动态的添加更多功能的一种方法。 如果需要为一个主类里添加新的字段,新的方法和新的逻辑,而这些新加入的东西仅仅是为了满足一些只在某种特定情况下才会执行的特殊行为, 那么就...
设计模式 - 装饰模式(C++实例) 若有问题,请指出。
软件设计模式之装饰模式讲解ppt,可用于教学课件。
设计模式C++学习之装饰模式(Decorator)
装饰模式的示例代码和文档,学习装饰模式的参考资料。
根据售卖咖啡的过程,客户先选择一种口味的咖啡,又选择不同种类的配料,由于配料选择是不定的,符合装饰模式的应用情况。
23种设计模式--装饰模式
装饰模式简单例子,根据《Head First设计模式》第3章中的咖啡店的例子编写
Java的装饰模式的实例代码,生成密码的实例
实验九:装饰模式.rar实验九:装饰模式.rar中有小猪游戏,肖像画加装饰物以及咖啡茶的装饰
通过设计组装和升级大众CC来说明装饰模式,有一个VolkCC类实现Volk接口,设计一个CCDecorator实现Volk这个接口,在ConcreteCCDecorator这个具体装饰角色中进行功能的增加和重写。
装饰模式(Decorator),动态地给一个对象添加一些额外的职责,就增加功能来说,装饰模式比生成子类更为灵活。
C#设计模式之Decorator 装饰模式,pdf+视频教学,实例演示,易学易用~~