科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件无废话C#设计模式之八:Facade

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

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本系列文章将向大家介绍一下C#的设计模式,此为第八篇文章,相信对大家会有所帮助的。废话不多说,继续来看。

作者:LoveCherry 来源:博客园 2007年11月19日

关键字:

  • 评论
  • 分享微博
  • 分享邮件
代码说明

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

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

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

  何时采用

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

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

  实现要点

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

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

  注意事项

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

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章