无废话C#设计模式之八:Facade

转载 2011年01月18日 13:25:00

无废话C#设计模式之八:Facade

 

意图

 

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

 

场景

 

       在一个为游戏充值的网站中,创建订单需要与三个外部接口打交道:

l         用户系统:根据用户名获取用户ID、查看用户是否已经激活了游戏

l         卡系统:查看某种类型的充值卡是否还有库存

l         充值系统:创建一个订单,并且返回订单号

如果直接让网站和三个外部接口发生耦合,那么网站因为外部系统接口修改而修改的概率就很大了,并且就这些小接口来说并不是十分友善,它们提供的大多数是工具方法,具体怎么去使用还是要看充值网站创建订单的逻辑。

Facade的思想就是在小接口上封装一个高层接口,屏蔽子接口的调用,提供外部更简洁,更易用的接口。

 

示例代码

 

using System;

using System.Collections.Generic;

using System.Text;

 

namespace FacadeExample

{

    class Program

    {

        static void Main(string[] args)

        {

            PayFacacde pf = new PayFacacde();

            Console.WriteLine("order:" + pf.CreateOrder("yzhu", 0, 1, 12) + " created");

        }

    }

 

    class PayFacacde

    {

        private AccountSystem account = new AccountSystem();

        private CardSystem card = new CardSystem();

        private PaySystem pay = new PaySystem();

 

        public string CreateOrder(string userName, int cardID, int cardCount, int areaID)

        {

            int userID = account.GetUserIDByUserName(userName);

            if (userID == 0)

                return string.Empty;

            if (!account.UserIsActived(userID, areaID))

                return string.Empty;

            if (!card.CardHasStock(cardID, cardCount))

                return string.Empty;

            return pay.CreateOrder(userID, cardID, cardCount);

        }

    }

 

    class AccountSystem

    {

        public bool UserIsActived(int userID, int areaID)

        {

            return true;

        }

 

        public int GetUserIDByUserName(string userName)

        {

            return 123;

        }

    }

 

    class CardSystem

    {

        public bool CardHasStock(int cardID, int cardCount)

        {

            return true;

        }

    }

 

    class PaySystem

    {

        public string CreateOrder(int userID, int cardID, int cardCount)

        {

            return "0000000001";

        }

    }

}

 

代码执行结果如下图:

 

 

代码说明

 

l         PayFacade类就是门面类型,提供给客户端调用,它本身调用子接口。可以看到,创建一个订单首先要根据用户名获取用户ID、然后要看用户是否已经激活了游戏、然后看充值卡是否有库存,最后才是创建订单。

l         AccountSystemCardSystem以及PaySystem就是子接口,它们提供了账户、卡以及充值相关的一些接口方法。

l         Facade模式太常用了,把和多方关联的逻辑代码再进行一次封装,提供一个高层接口就是Facade的思想。比如在做论坛程序的时候,一些操作需要调用权限访问模块(发帖、管理帖子),另外一些操作可以直接调用(首页论坛板块、登陆)数据访问模块,由网站来做这个判断并调用不同的子模块并不合适,可以加一个业务逻辑层来统一接受网站各种操作请求,这其实就是Facade

 

何时采用

 

l         从代码角度来说, 如果你的程序有多个类是和一组其它接口发生关联的话可以考虑在其中加一个门面类型。

l         从应用角度来说, 如果子系统的接口是非常细的,调用方也有大量的逻辑来和这些接口发生关系,那么就可以考虑使用Facade把客户端与子系统的直接耦合关系进行化解。你可能会说,子系统改了门面不是照样改?的确是需要改,但是如果客户端本身的工作已经比较复杂,或者说可能有多个需要调用门面的地方,这个时候门面的好处就体现了。

 

实现要点

 

l         通过一个高层接口让子系统和客户端不发生直接关联,使客户端不受子系统变化的影响。

l         Facade不仅仅针对代码级别,在构架上,特别是WEB应用程序的构架上,Facade的应用非常普遍。

 

注意事项

 

l         Facade不一定只能是一个,可以考虑把门面进行细分。

无废话C#设计模式之八:Facade

 意图        为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。 场景        在一个为游戏充值的网站中,创建订单需要与三个...
  • xjj51296646
  • xjj51296646
  • 2009年01月05日 12:06
  • 397

C# 设计模式--外观模式(Facade)

     一个良好的面向对象应用程序应该是一个最小的类,这个类能够把其他可重用类的行为有效的组织起来。对一个子系统的类进行重构,直到每个类都有一个进行良好定义功能目标,所以代码易于维护。外观模式(Fa...
  • scucj
  • scucj
  • 2006年11月09日 00:22
  • 3210

Facade模式详解--设计模式(11)

Facade模式 一 意图   为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。 二 动机   将一个系统划分成为若干个子系统有...
  • fanyun_01
  • fanyun_01
  • 2016年06月29日 08:57
  • 1350

无废话MVC系列教程

http://www.cnblogs.com/iamlilinfeng/category/454097.html MVC入门教程 摘要: 一、前言以下是我自己写的MVC入门教程和一个外...
  • SalmonellaVaccine
  • SalmonellaVaccine
  • 2014年05月24日 02:24
  • 1158

Firefox插件/扩展开发之Hello World无废话版

有一点你要明白,你要开发的其实是扩展(extension),而不是插件(plugin)。我们的目标在FireFox的状态栏显示Hello World,如下图所示:1. 准备工作下载FireFox,我使...
  • ZJXHZ
  • ZJXHZ
  • 2008年11月23日 15:37
  • 1412

23种设计模式(1)-Facade设计模式

前记        曾经我遇见的一个需求是这样的,接口A有个方法void methodA(),类B需要实现接口A的methodA()方法,并且在类B中需要把methodA()方法内部处理逻辑获得的结...
  • duchao123duchao
  • duchao123duchao
  • 2016年05月16日 14:47
  • 3390

随笔分类 - 无废话ExtJs系列教程

随笔分类 - 无废话ExtJs系列教程 http://www.cnblogs.com/iamlilinfeng/archive/2012/07/10/2585232.html ExtJs ...
  • zdy0_2004
  • zdy0_2004
  • 2015年10月03日 15:25
  • 576

Java 设计模式 之 facade(外观)设计模式

Facade模式要求一个子系统的外部与其内部的通信通过一个统一的Facade对象进行。Facade模式提供一个高层次的接口,使得子系统更易于使用。       当子系统经过不断的演变,变得异常复杂时,...
  • u010349169
  • u010349169
  • 2014年01月28日 17:24
  • 2922

pureMVC与设计模式之二. Facade模式与Singleton模式

引言 上篇文章,我们分析了pureMVC的结构以及工作流。从本文开始,将逐个解剖其中设计到的设计模式。我们先看facade模式和singleton模式。 一、pureMVC中的Facade模式...
  • ywjun0919
  • ywjun0919
  • 2015年05月05日 10:04
  • 576

无废话C#设计模式之九:Proxy

 意图        为其他对象提供一种代理以控制对这个对象的访问。 场景 代理模式非常常用,大致的思想就是通过为对象加一个代理来降低对象的使用复杂度、或是提升对象使用的友好度、或是提高对象使用的效率...
  • xjj51296646
  • xjj51296646
  • 2009年01月05日 12:07
  • 367
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:无废话C#设计模式之八:Facade
举报原因:
原因补充:

(最多只允许输入30个字)