1、定义
将抽象与实现分离,使它们可以独立变化。它是用组合关系代替继承关系来实现,从而降低了抽象和实现这两个可变维度的耦合度。
2、角色划分
2.1抽象化(Abstraction)角色
定义抽象类,并包含一个对实现化对象的引用。
2.2扩展抽象化(Refined Abstraction)角色
是抽象化角色的子类,实现父类中的业务方法,并通过组合关系调用实现化角色中的业务方法。
2.3实现化(Implementor)角色
定义实现化角色的接口,供扩展抽象化角色调用。
2.4具体实现化(Concrete Implementor)角色
给出实现化角色接口的具体实现。
3、UML关系图
image.png4、优点
1.由于抽象与实现分离,所以扩展能力强;
2.其实现细节对客户透明。
5、缺点
由于聚合关系建立在抽象层,要求开发者针对抽象化进行设计与编程,这增加了系统的理解与设计难度。
6、代码实现
调用
//来一大杯加冰咖啡
let ice = IceAddtives()
let coffee = BigCoffee.init(ice)
coffee.makeCoffee()
//来一小杯加糖咖啡
let addtive = SugarAddtives()
let coffee2 = SmallCoffee.init(addtive)
coffee2.makeCoffee()
实现
//抽象部分:咖啡添加剂
class CoffeeAddtives: NSObject {
//业务逻辑
func addtives() -> String {
return ""
}
}
class IceAddtives: CoffeeAddtives {
override func addtives() -> String {
return "加冰"
}
}
class NonIceAddtives: CoffeeAddtives {
override func addtives() -> String {
return "不加冰"
}
}
class SugarAddtives: CoffeeAddtives {
override func addtives() -> String {
return "加糖"
}
}
class NonSugarAddtives: CoffeeAddtives {
override func addtives() -> String {
return "不加糖"
}
}
//抽象的实现部分->型号
//特点:持有抽象部分的引用
class Coffee: NSObject {
var addtives: CoffeeAddtives
init(_ addtives:CoffeeAddtives) {
self.addtives = addtives
}
func makeCoffee() {
}
}
class BigCoffee: Coffee {
override func makeCoffee() {
print("大杯\(addtives.addtives())的咖啡")
}
}
class MidduleCoffee: Coffee {
override func makeCoffee() {
print("中杯\(addtives.addtives())的咖啡")
}
}
class SmallCoffee: Coffee {
override func makeCoffee() {
print("小杯\(addtives.addtives())的咖啡")
}
}
网友评论