介绍
中介者模式(Mediator Pattern) 也成为调节者模式或调停者模式。
定义
中介者模式包装了一系列对象相互作用的方式,使得这些对象不必相互明显作用。从而使他们可以松散耦合。当某些对象之间的作用发生改变时,不会立刻影响其他的一些对象之间的作用。保证这些作用可以彼此独立的变化。中介者模式将多对多的相互作用转化为一对多的相互作用。中介者模式将对象的行为和协作抽象化,把对象在小尺度的行为上与其他对象的相互作用分开处理。
使用场景
当对象之间的交互操作很多且每个对象的行为操作都依赖彼此时,为防止在修改一个对象的行为时,同时涉及修改很多其它对象的行为,可采用中介者模式,来解决紧耦合问题。该模式将对象之间的多对多关系变成一对多关系,中介者对象将系统从网状结构变成以调停者为中心的星行结构,达到降低系统的复杂性,提高可扩展的作用。
角色介绍
Mediator 抽象中介者角色,定义了同事对象到中介者对象的接口,同事对象指的是多个相互作用的对象。还定义了抽象中介方法,抽象中介方法用来与同事对象交互。抽象中介者角色一般以抽象类的方式实现
ConcreteMediator 具体中介者角色,继承于抽象中介者,实现了父类定义的方法,它从具体的同事对象接收消息,向具体的同事对象发出命令。
Colleague 抽象的同事类角色,定义了中介者对象的接口,它只知道中介者而不知道其他同事对象
ConcreteColleague 具体的同事类角色,继承于抽象同事类,每个具体同事类都知道本身在小范围内的行文,而不知道它在大范围内的目的。
在中介者中保存各个同事对象的引用,各个同事对象中也有中介者对象的引用。当某个同事对象的状态发生改变时,会通知中介者其发生了改变,这时中介者会根据发生改变的同事对象以及发生的改变通知其他需要产生交互的同事对象,其通知方法为调用需要被通知的同事对象的特定方法。从而以低耦合的方式完成不同同事对象之间的交互。
Android 源码中的中介者模式
Keyguard 锁屏功能实现,KeyguardViewMediator 中,看到很多 XXXManager 管理器的成员变量,各种各样的管理器就是各个具体的同事类, Android 使用 KeyguardViewMediator 来充当中介者协调这些管理器的状态改变,并且该类中也定义了很多方法来处理这些管理器的状态。例如锁屏音效的播放,KeyguardViewMediator 中对应 playSounds 方法来协调音频的这一状态。KeyguardViewMediator 中还有很多类似的协调方法。
开发实例
在界面开发过程中,某些 UI 控件的状态会影响其他控件的状态,这时候我们在 Activity 中为各个控件设置监听,当控件状态改变时都将其信息传给 Activity,再由 Activity 来通知其他控件发生交互,Activity 充当中介者来协调这些控件的状态。
总结
在多个类依赖关系如网状般复杂时,适当的使用中介者模式可以对这种依赖关系进行解耦使逻辑结构清晰。
但是如果几个类直接依赖关系并不复杂,使用中介者模式反而使原本不复杂的逻辑结构变得复杂。
因此我们决定使用中介者模式之前要多方考虑,权衡利弊。