装饰模式:动态给一个对象添加一些额外的职责,就像在墙上刷油漆,使用装饰模式相比生成子类达到的功能更加灵活
【场景】使用继承来实现功能的扩展,如果扩展的功能种类繁多,那么势必生成很多子类
【要点】装饰着与被装饰者拥有共同的超类,,继承的目的是继承类型,而不是行为
扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式
我们一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【继承于统一根源,是为了同源】
装饰之后还是调用那几中方法【目的不是继承行为,因为装饰之后还是那些行为】
其实这个更多是用于添加外形,粉饰一新,盖头换面
比较典型的就是游戏角色,的装饰,武器等的扩展,绚丽的衣着
装饰者模式的设计原则为:对扩展开放、对修改关闭,这句话体现在我如果想扩展被装饰者类的行为,无须修改装饰者抽象类,只需继承装饰者抽象类,实现额外的一些装饰或者叫行为即可对被装饰者进行包装。所以:扩展体现在继承、修改体现在子类中,而不是具体的抽象类,这充分体现了依赖倒置原则,这是自己理解的装饰者模式。
相关推荐
### 开发模式之装饰模式详解 #### 装饰模式定义 装饰模式(Decorator Pattern)是一种结构型设计模式,允许向对象动态地添加新的功能,而无需修改其原有结构。这种模式通过创建一个新的包装类来包裹真实的对象,...
装饰模式是一种设计模式,它允许我们在不修改原有对象的基础上,通过添加新的行为或属性来扩展对象的功能。在"装饰模式小猪快跑游戏模拟"这个实例中,我们看到这种模式被巧妙地应用到了一个名为“小猪吃苹果”的游戏...
装饰模式是一种结构型设计模式,它允许我们向一个对象动态地添加新的行为或责任,而无需修改该对象的源代码。在C#中,装饰模式是通过创建一个包装类(Decorator),该包装类实现了与被装饰对象相同的接口,并持有被...
【装饰模式】是一种设计模式,源自Erich Gamma等人编写的《设计模式:可重用面向对象软件的基础》一书。这种模式在Swing开发中尤为常见,用于增强或改进现有对象的功能,尤其在Web应用程序中,如Java的J2EE环境,...
装饰模式是一种设计模式,属于结构型模式,其主要目的是在不改变对象本身的基础上,通过向对象添加新的行为或属性来扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭。 在装饰模式中,有四个关键...
装饰模式是一种结构型设计模式,它允许在运行时给对象添加新的行为或责任,而无需修改对象的源代码。在Java中,装饰模式通常通过继承和组合来实现,提供了比子类化更灵活的方式来扩展对象的功能。 装饰模式的核心...
装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在软件工程中非常常见,因为它提供了灵活性,使得我们可以独立于对象的组合来扩展功能。 在C++中,装饰...
装饰模式是一种结构型设计模式,它允许在运行时动态地给对象添加新的行为或属性,而不必修改原有类的代码。这种模式的核心在于装饰者和组件接口的统一,使得装饰者可以替代原对象并添加额外的功能。在"设计模式之...
装饰模式(Decorator)是软件设计领域中一种非常实用的结构型设计模式,它允许我们向一个对象添加新的行为或责任,而无需修改该对象的源代码。在C++编程语言中,装饰模式常用于动态地扩展类的功能,使得类的行为在...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。装饰模式通常用于为已有对象添加...
装饰模式(Decorator Pattern)是设计模式中的一种结构型模式,它在不改变原有对象的基础上,通过添加额外的职责来扩展对象的功能。在C#中,装饰模式尤其适用于那些需要动态地增加或减少对象功能的情况,避免了使用...
装饰模式是一种设计模式,它允许在不改变对象自身的情况下,动态地给对象添加新的行为或职责。这种模式常用于在不修改源代码的情况下扩展对象的功能,或者为对象提供额外的职责。在本例中,"项目经理接到一个项目,...
装饰模式是一种设计模式,它允许我们在不改变对象本身的情况下,为对象添加新的行为或属性,从而扩展其功能。这种模式遵循“开闭原则”,即对扩展开放,对修改关闭,这意味着我们可以灵活地增加一个对象的功能,而...
装饰模式是一种结构型设计模式,它允许我们向现有的对象添加新的功能,同时又不破坏其原有的结构。在C#中,装饰模式常用于在运行时动态地改变对象的行为,而无需修改原始类的代码。这种模式的核心在于装饰者类与被...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或职责,而无需修改对象的源代码。这种模式在软件工程中非常有用,因为它提供了灵活性,使得代码可以在不破坏封装性的前提下进行扩展。 在"实验九:装饰...
装饰模式是一种设计模式,它允许在不修改对象本身的情况下,通过包装(或“装饰”)对象来动态地扩展其功能。在面向切面编程(Aspect Oriented Programming, AOP)中,装饰模式常被用来实现在运行时向目标对象添加...
装饰模式是一种结构型设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式通常用于保持对象的原始类结构不变,同时增强其功能。HeadFirst 设计模式系列书籍以其生动有趣的插图和...
装饰模式是一种结构型设计模式,它允许我们向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在不违背开闭原则(对扩展开放,对修改关闭)的前提下,提供了灵活的扩展机制。在《Head First设计模式》一书...
装饰模式是一种结构型设计模式,它是面向对象设计中用来动态添加或修改对象功能的一种方法。在软件工程中,装饰模式允许我们向一个现有的对象添加新的行为或职责,同时又不改变其原有的结构,从而实现对类的功能扩展...
装饰模式是一种设计模式,它允许在运行时向对象添加新的行为或责任,而无需修改对象的源代码。这种模式在Java等面向对象编程语言中非常常见,因为它提供了灵活性,使得扩展对象的功能变得容易且优雅。在这个"装饰...