雨光

rayrain

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

名称

外观(Facade)

结构


意图

为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。

适用性

  • 当你要为一个复杂子系统提供一个简单接口时。子系统往往因为不断演化而变得越来越复杂。大多数模式使用时都会产生更多更小的类。这使得子系统更具可重用性,也更容易对子系统进行定制,但这也给那些不需要定制子系统的用户带来一些使用上的困难。外观可以提供一个简单的缺省视图,这一视图对大多数用户来说已经足够,而那些需要更多的可定制性的用户可以越过外观层。
  • 客户程序与抽象类的实现部分之间存在着很大的依赖性。引入外观将这个子系统与客户以及其他的子系统分离,可以提高子系统的独立性和可移植性。
  • 当你需要构建一个层次结构的子系统时,使用外观模式定义子系统中每层的入口点。如果子系统之间是相互依赖的,你可以让它们仅通过外观进行通讯,避免子系统间直接连接,从而简化了它们之间的依赖关系。
  • 希望隐藏原有系统,屏蔽子系统的复杂性。
  • 希望使用原有系统的部分功能,并且希望增加一些新功能。
  • 需要为复杂的子系统提供一个简单接口。

缺陷

  • 虽然外观模式简化了子系统,但是,由于简化后的外观并不完整,因此某些未预见的功能对客户是不可用的,限制了客户的自由。

 

posted on 2009-07-24 23:38  rayrain  阅读(127)  评论(0编辑  收藏  举报