Facade外觀模式,是一種結(jié)構(gòu)型模式,它主要解決的問題是:組件的客戶和組件中各種復雜的子系統(tǒng)有了過多的耦合,隨著外部客戶程序和各子系統(tǒng)的演化,這種過多的耦合面臨很多變化的挑戰(zhàn)。在這里我想舉一個例子:比如,現(xiàn)在有一輛汽車,我們(客戶程序)要啟動它,那我們就要發(fā)動引擎(子系統(tǒng)1),使四個車輪(子系統(tǒng)2)轉(zhuǎn)動。但是實際中我們并不需要用手推動車輪使其轉(zhuǎn)動,我們踩下油門,此時汽車再根據(jù)一些其他的操作使車輪轉(zhuǎn)動。油門就好比系統(tǒng)給我們留下的接口,不論汽車是以何種方式轉(zhuǎn)動車輪,車輪變化成什么牌子的,我們要開走汽車所要做的還是踩下油門。
GoF《設(shè)計模式》中說道:為子系統(tǒng)中的一組接口提供一個一致的界面,Facade模式定義了一個高層接口,這個接口使得這一子系統(tǒng)更加容易使用。
Façade外觀模式的結(jié)構(gòu)大概是這樣的:
我就上面說的那個情形寫一下實現(xiàn)代碼,首先我們要實現(xiàn)三個子系統(tǒng)(Wheel、Engine、Body):
internal class Engine
{
public string EngineWork()
{
return "BMW‘s Engine is Working";
}
public string EngineStop()
{
return "BMW‘s Engine is stoped";
}
}
internal class Wheel
{
public string WheelCircumrotate()
{
return "BMW‘s Wheel is Circumrotating";
}
public string WheelStop()
{
return "BMW‘s Wheel is stoped";
}
}
internal class Body
{
public Wheel[] wheels = new Wheel[4];
public Engine engine = new Engine();
public Body()
{
for (int i = 0; i < wheels.Length; i++)
{
wheels[i] = new Wheel();
}
}
}
然后,我們再來實現(xiàn)汽車的Facade
class CarFacade
{
Body body = new Body();
public void Run()
{
Console.WriteLine(body.engine.EngineWork());
for(int i = 0; i < body.wheels.Length; i++)
{
Console.WriteLine(body.wheels[i].WheelCircumrotate());
}
}
public void Stop()
{
Console.WriteLine(body.engine.EngineStop());
for (int i = 0; i < body.wheels.Length; i++)
{
Console.WriteLine(body.wheels[i].WheelStop());
}
}
}
現(xiàn)在我們來使用客戶端程序驗證一下,代碼如下:
class Program
{
static void
{
CarFacade car = new CarFacade();
car.Run();
car.Stop();
Console.Read();
}
}
執(zhí)行結(jié)果如下;
BMW‘s Engine is Working
BMW‘s Wheel is Circumrotating
BMW‘s Wheel is Circumrotating
BMW‘s Wheel is Circumrotating
BMW‘s Wheel is Circumrotating
BMW‘s Engine is stoped
BMW‘s Wheel is stoped
BMW‘s Wheel is stoped
BMW‘s Wheel is stoped
BMW‘s Wheel is stoped
正如上面所說:客戶端代碼(Program)不需要關(guān)心子系統(tǒng),它只需要關(guān)心CarFacade所留下來的和外部交互的接口,而子系統(tǒng)是在CarFacade中聚合。
Façade模式的幾個要點:
1、從客戶程序的角度看,Facade模式不僅簡化了整個組件系統(tǒng)的接口,同時對于組件內(nèi)部與外部客戶程序來說,從某種程度上也達到了一種“解耦”的效果——內(nèi)部子系統(tǒng)的任何變化不會影響到Facade接口的變化。
2、Facade設(shè)計模式更注重從架構(gòu)的層次去看整個系統(tǒng),而不是單個類的層次。Facade很多時候更是一種架構(gòu)設(shè)計模式。