桥接模式:是一种结构型模式,较好地适应两个或者多个维度的变化,假如使用继承则过于臃肿或者是的设计变得臃肿。
<!--?xml version="1.0" encoding="UTF-8" standalone="no"?-->
桥接模式将变化抽象分出来,使得变化的部分与主类分离开来,进而将多个维度的变化分离开来。然后通过一个管理类来将这些多个维度的事物进行柔和,进而满足业务需求 。
我们举一个电视机开关的应用,电视有很多牌子,开关大不相同,但是功能都是相同:开关电视,很符合桥接模式的场景。
定义两个个protocol:开关和应用
<!--?xml version="1.0" encoding="UTF-8" standalone="no"?-->
protocol
Switch{
func onOrOff()
}
protocol Application{
func turnOnOrOff()
}
func onOrOff()
}
protocol Application{
func turnOnOrOff()
}
不同的电视和开关:
<!--?xml version="1.0" encoding="UTF-8" standalone="no"?--> class TVSwitch: Switch {
internal var application:Application?
required init(app:Application){
self.application = app
}
func onOrOff() {
assert(self.application != nil, "怒能为空")
self.application!.turnOnOrOff()
}
}
class ChangHongTV:Application {
func turnOnOrOff() {
println("开关长虹电视")
}
}
class HaierTV: Application {
func turnOnOrOff() {
println("开关海尔彩电")
}
}
internal var application:Application?
required init(app:Application){
self.application = app
}
func onOrOff() {
assert(self.application != nil, "怒能为空")
self.application!.turnOnOrOff()
}
}
class ChangHongTV:Application {
func turnOnOrOff() {
println("开关长虹电视")
}
}
class HaierTV: Application {
func turnOnOrOff() {
println("开关海尔彩电")
}
}
将二者行为关联起来,搞个小孩子开关电视
<!--?xml version="1.0" encoding="UTF-8" standalone="no"?--> class ABoy {
var sw = TVSwitch(app: nil)
func operaTV(tv:Application){
if let tvSwitch = sw.application{
}else{
sw.application = tv
}
println("小朋友开关")
sw.onOrOff()
}
}
var haier = HaierTV()
var boy = ABoy()
boy.operaTV(haier)
var sw = TVSwitch(app: nil)
func operaTV(tv:Application){
if let tvSwitch = sw.application{
}else{
sw.application = tv
}
println("小朋友开关")
sw.onOrOff()
}
}
var haier = HaierTV()
var boy = ABoy()
boy.operaTV(haier)