Mediator的意思是中介者、調節者、傳遞物,顧名思義,這個模式在程式中必然負擔一個中介、調節、傳遞的工作。
在組織物件工作的同時,物件彼此之間可能知道彼此的存在,並相互依賴,這就使得物件之間的耦合性相對的提高,最差的情況下,所有的物件都知道彼此的存在,這會使得系統的重用性降低。
Mediator模式用一個中介的物件來封裝物件彼此之間的交互,物件之間並不用互相知道另一方,這可以降低物件之間的耦合性,如果要改變物件之間的交互行為,也只需要對Mediator加以修改即可。
例如對話方塊組件,當一個特定的輸入欄為空時,另一個按鈕不能使用;在ListBox的選項中選擇一個項目,將會改變另一個欄位的內容;反過來的,輸入欄位的內容也會影響ListBox的選擇等。
在這個例子中,雖然可以設計對話方塊中的組件知道彼此的存在,由一個直接影響另一個(或多個)組件,但最好的方法,還是設計一個Mediator,由它來協調組件之間的交互,例如設計一個FontDialogDirector類別來作為中介者:
可以從順序圖來瞭解Mediator的運作:
當ListBox發生變化時,它會呼叫Mediator的listBoxChanged()方法,Mediator取得變化的組件之狀態,並重新設定所有 與它有互動的組件,同樣的,其它的組件發生變化時,也呼叫Mediator上對應的方法,由Mediator來取得組件變化,並設定其它互動的組件。
簡單的說,Mediator設計有與組件溝通的介面,介面中封裝了與其它組件互動細節,組件與組件之間不用知道彼此的存在,它們只要與Mediator溝通就好了,利用這種方式,可以切開組件與組件之間的耦合。
Mediator模式的 UML 結構圖如下所示:
在類別圖中可以注意的是類別的名稱,Colleague是同事的意思,將一群共事的元件視為一群共同合作的同事,為了使同事之間的活動獨立,並使得 團隊合作的交互更具彈性,需要一個Mediator來協調同事之間的商務行為。