1、 概念
为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,该接口使子系统更加容易使用。
2、 模型
public class ModularA { public void ModularAMethod() { Console.WriteLine("A模块的方法。"); } } public class ModularB { public void ModularBMethod() { Console.WriteLine("B模块的方法。"); } } public class ModularC { public void ModularCMethod() { Console.WriteLine("C模块的方法。"); } } public class FaCade { private ModularA mda; private ModularB mdb; private ModularC mdc; public FaCade() { mda = new ModularA(); mdb = new ModularB(); mdc = new ModularC(); } public void FaCadeMethod()//该方法负责对外的联系 { mda.ModularAMethod(); mdb.ModularBMethod(); mdc.ModularCMethod(); } }
客户端
//如果不用外观模式,则客户端分别要调用ModularA,ModularB,ModularC,耦合就强了。 //ModularA mda = new ModularA(); //ModularB mdb = new ModularB(); //ModularC mdc = new ModularC(); //mda.ModularAMethod(); //mdb.ModularBMethod(); //mdc.ModularCMethod(); //使用外观模式,客户端只关心FaCade的方法,之和这一个类发生联系,减少了耦合。 FaCade fd = new FaCade(); fd.FaCadeMethod(); Console.ReadLine();
结果
其实这种模式,在平时写代码时那是经常使用的,有时候写一个单独的功能模块,就有这样的一个类,负责与外界交流,接受传入的参数,并负责传出结果,外部是不需要关心模块如何实现,往往是引用这个类传入某些值,该类再传出结果,至于如何实现功能那就是这个模块的事了。因此减少了这个模块与外界的接触,而且如果该模块的内部算法除了问题,不会影响其他模块运行,只是表现在结果不正确而已。而且我一般写单独模块都把里面的public除了要和外界交互的类,其它都写成internal,强制外面访问不到内部的细节。