《大话设计模式》——读后感 (9)牛市股票还会亏钱?——外观模式

原文中对外观模式的定义为:

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

从定义理解:

1、外观模式是为子系统提供一组接口服务的,不是一个接口,是一组;既然是一组接口,就有可能需要和很多类、很多方法打交道

2、外观模式自己也要定义个高层接口,而这个接口就是为子系统中的一组接口服务的。专业说是对子系统中在接口实现类进行逻辑封装。

3、上一篇的建造者模式,强调的是将复杂对象构建与表示分离;而外观模式则侧重子系统,有可能有很多子系统,侧重点完全不一致

UML的构造图:

从UML图中,我们看到客户端只是和外观模式的Facede打交道,根本不关心子系统类集合实现子系统的功能;这样大大降低子系统与客户端的耦合度,且客户端调用非常方便

外观模式包含如下两个角色:

      (1) Facade(外观角色):在客户端可以调用它的方法,在外观角色中可以知道相关的(一个或者多个)子系统的功能和责任;在正常情况下,它将所有从客户端发来的请求委派到相应的子系统去,传递给相应的子系统对象处理。

      (2) SubSystem(子系统角色):在软件系统中可以有一个或者多个子系统角色,每一个子系统可以不是一个单独的类,而是一个类的集合,它实现子系统的功能;每一个子系统都可以被客户端直接调用,或者被外观角色调用,它处理由外观类传过来的请求;子系统并不知道外观的存在,对于子系统而言,外观角色仅仅是另外一个客户端而已。

使用场景

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

  外观模式中所指的子系统是一个广义的概念,它可以是一个类、一个功能模块、系统的一个组成部分或者一个完整的系统。子系统类通常是一些业务类,实现了一些具体的、独立的业务功能,其典型代码如下:

模拟各个子系统:

class SubSystemA
{
    public void methodA()
    {
        //业务实现代码
    }
}  

class SubSystemB
{
    public void methodB()
    {
        //业务实现代码
     }
}  

class SubSystemC
{
    public void methodC()
    {
        //业务实现代码
    }
}  

在引入外观类之后,与子系统业务类之间的交互统一由外观类来完成,在外观类中通常存在如下代码:

class Facade
{
    private SubSystemA obj1 = new SubSystemA();
    private SubSystemB obj2 = new SubSystemB();
    private SubSystemC obj3 = new SubSystemC();  

    public void method1()
    {
        obj1.methodA();
        obj2.methodB();
        obj3.methodC();
    }  

  
  public void method2()
    {
        obj1.methodA();
        obj3.methodC();
    }  
} 

由于在外观类中维持了对子系统对象的引用,客户端可以通过外观类来间接调用子系统对象的业务方法,而无须与子系统对象直接交互。引入外观类后,客户端代码变得非常简单,典型代码如下:

public class Client
{
    public static void Main(string[] args)
    {
        Facade facade = new Facade();  

     //某项业务需求,需要调用Method1方法
        facade.method1();  

  
       //某项业务需求,此时需要调用Method2方法        facede.method2();
} } 

至此,外观模式解释完毕,一句话概括:外观模式是对其他子系统部分功能进行组合、封装。

时间: 2024-10-25 04:32:22

《大话设计模式》——读后感 (9)牛市股票还会亏钱?——外观模式的相关文章

牛市股票还是亏钱—外观模式

外观模式(Facade Pattern):为了系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 外观模式(Facade Pattern)结构图 Facade外观类知道哪些子系统负责处理请求,将客户的请求代理给适当的子系统对象.SubSystem Classes 子系统类集合实现子系统的功能,处理Facade对象指派的任务.注意子类中没有Facade的任何信息,即没有对Facade对象的引用. 四个子系统的类: class SubSystemOne

大话设计模式pdf

下载地址:网盘下载 内容简介  · · · · · · 本书通篇都是以情景对话的形式,用多个小故事或编程示例来组织讲解GOF(设计模式的经典名著--Design Patterns:Elements of Reusable Object-Oriented Software,中译本名为<设计模式--可复用面向对象软件的基础>的四位作者EIich Gamma.Richard Helm.Ralph Johnson,以及John Vlissides,这四人常被称为Gang of Four,即四人组,简称

《大话设计模式》PDF

下载地址:网盘下载 内容简介  · · · · · · 本书通篇都是以情景对话的形式,用多个小故事或编程示例来组织讲解GOF(设计模式的经典名著--Design Patterns:Elements of Reusable Object-Oriented Software,中译本名为<设计模式--可复用面向对象软件的基础>的四位作者EIich Gamma.Richard Helm.Ralph Johnson,以及John Vlissides,这四人常被称为Gang of Four,即四人组,简称

《大话设计模式》读后感

第一次读<大话设计模式>,是在刚接触C#的时候.疲累于大部头的官方教材中时,无意间翻开了这本生动有趣的书,甚是眼前一亮.由于当时C#基础薄弱,只是把它当小说来看,如饥似渴,饶有滋味,一口气看到凌晨四点,被不知觉间流逝的时间吓傻了. 而今重读,更多的是想重温设计模式的应用场景和感受小菜对编程的热忱.一边做笔记一边看书,初步弄懂UML类图,效率果然高很多.感动也颇多.师傅领进门,修行看个人呀. 对程序员来说,精彩的代码是如何想出来的,要比看到精彩的代码更加令人期待.正如做一个足球运动员(软件设计编

《大话设计模式》——读后感 (2)商场促销?——策略模式

 按照我的习惯,先看策略模式UML结构图: 从图中,我看到了Strategy类,还有具体的实现类,还有一个Context,感觉和简单工厂好像啊,只是名字不一样而已.此处,我还用接口. 什么是策略模式呢? 实现: 原文是针对商场促销进行各种各样的打折进行设计案例的,而大话设计模式中还提到: 等等,打折.返现等等一系列促销具体方式只是一些算法,而算法本身也是一种策略.那我在此就要偷懒了: Operation接口,OperationAdd.OperationDelete.OperationDIv.Op

大话设计模式之策略模式读后感

策略模式:定义了算法家族,分别封装起来,让他们呢之间可以互相的替换,此模式让算法的变化不会影响到使用算法的客户. UML类图: 解读:策略模式是定义一系列的算法,从概念上来讲,这些算法完成的工作都是一样的,只是他们的实现的不同,可以以相同的方式调用所有的算法,减少了各种算法类和算法调用类之间的耦合. 策略模式中的supperStrategy为context类提供了一系列的可供重用的算法或者行为.继承有助于提取出这些算法的公共功能. 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转

《大话设计模式》——读后感 (1)代码无错就是优?——简单工厂模式

本篇是我学习设计模式后的第一篇文章,由于本模式也比较简单,在此我就多啰嗦一下. 学习本模式之前请下看一下我的<大话设计模式铺垫>文章,然后回答思考如下问题: 1.UML类图看懂了吗?2.java的3大特性真的懂了吗?知道为什么要封装.继承.多态了吗? 对于和我一样的菜鸟而言,我根本就不知道什么是设计模式,那怎么办?学呗.怎么样的学习设计模式呢?看UML类图,然后结合代码加以理解,废话不多刷,先上图: 从图中我独处了如下信息: 1.运算类是个抽象类,而不是接口.(不懂就去看UML类图) 2.加.

《大话设计模式》——读后感 (10)无尽加班何时休?——状态模式

原文定义: 状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象看起来像是改变其类[DP] UML结构图: 背景:   看到此模式,酝酿了好久才决定对状态模式进行总结.光看原文定义,实在没有获取到什么有用的价值. 第一眼看到状态模式,感觉这不就是一个简单工工厂模式吗?但是仔细看看其他人的博客,发现状态模式和简单工厂模式还是有一定的区别的,最明显的是Context类持有了State,这一点和简单工厂区别很大.但是我发现状态模式又和策略模式很像,或者说是太像了.同样有抽象接口,具体实现类,C

大话设计模式的整体总结

大话设计模式通过2个人的对话,讲述了在软件设计中的23个重要的设计模式和6大开发原则在生活中的应用和思想升华的过程,其中的小菜也代表了对面向对象很"了解"但是却脱离了现实开发中各种束缚的入门编程人员,大鸟则代表了在软件开发行业方面有丰富经验,并且能在具体生活中运用的高级开发人才.新老人员之间的对话没有那么多的浮华和不切实际,一开口就是软件开发应该怎么怎么样的,都是从生活的平常角度来解释这23个设计模式和6大原则的,熟悉的场景,通俗易懂的知识,引人入胜爱不释手,非常适合初级开发人员的学习