IronMan之外觀
接著上篇觀察者內容的“劇情”,沒看過的朋友也沒關系,篇幅之間有銜接的關系但是影響不大。
需求:
為"兵工廠"提供各種支持,生產了各式各樣的"IronMan",因為"IronMan"是智能的,它有一個"總控中心",用來使用各個部件的功能,以及 其它功能的使用。"總控中心"也是用戶在穿戴時顯示在用戶眼前的UI。
現在遇到一個問題,大家都來看一下,"IronMan"在穿戴好啟動的時候,"總控"會讓"IronMan"各個部件自動自檢,自檢完成後要在UI那顯示出 自檢的結果,當然自檢的順序可以是固定的也可以是不固定的,隨便怎麼檢查,最終是要返回所有的部件自檢結果。
假設的基礎結構情況:
1 public class Component1
2 {
3 public void Component1Inspection()
4 {
5 //部件1自檢
6 }
7 }
8 public class Component2
9 {
10 public void Component2Inspection()
11 {
12 //部件2自檢
13 }
14 }
15 public class Component3
16 {
17 public void Component3Inspection()
18 {
19 //部件3自檢
20 }
21 }
假設還有若干個部件,按照平常的狀態它們都要一一的自檢。在這樣的情況下使用的代碼則是這樣的:
1 /// <summary>
2 /// 控制中心
3 /// </summary>
4 public class CenterController
5 {
6 /// <summary>
7 /// 啟動時的行為
8 /// </summary>
9 public void StartBef()
10 {
11 Component1 com1 = new Component1();
12 com1.Component1Inspection();
13 Component2 com2 = new Component2();
14 com2.Component2Inspection();
15 Component3 com3 = new Component3();
16 com3.Component3Inspection();
17 }
18 }
這樣做下去的話是不是很費事,而且控制中心和部件的耦合度也比較大,如果部件個數自檢的修改也會牽扯到控制中心內部的修改,這樣的行為是違反設計原則的。
外觀模式(Facade)的定義:為子系統中的一組接口提供一個一致的界面,用來訪問子系統中的一群接口。
根據設計模式的中心思想來做修改,把部件自檢的操作都封裝在單獨的一層中,讓控制中心和部件解耦,我們來看一下修改後的代碼:
1 public class Facade
2 {
3 //自檢
4 public void Inspection()
5 {
6 Component1 com1 = new Component1();
7 com1.Component1Inspection();
8 Component2 com2 = new Component2();
9 com2.Component2Inspection();
10 Component3 com3 = new Component3();
11 com3.Component3Inspection();
12 }
13 }
這樣定義了外觀類過後,再來看一下控制中心的調用修改:
1 /// <summary>
2 /// 控制中心
3 /// </summary>
4 public class CenterController
5 {
6 /// <summary>
7 /// 啟動時的行為
8 /// </summary>
9 public void StartBef()
10 {
11 Facade facade = new Facade();
12 facade.Inspection();
13 }
14 }
在兩層中間加入了Facade這一層,耦合的問題就迎刃而解,好像好多解耦的方式都是這樣的。
END 下一篇是關於命令模式的說明。
作者:金源
出處:http://www.cnblogs.com/jin-yuan/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面