欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    外观模式.docx

    • 资源ID:5286913       资源大小:98.67KB        全文页数:14页
    • 资源格式: DOCX        下载积分:12金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要12金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    外观模式.docx

    1、外观模式开闭原则就是说模块应对扩展开放,而对修改关闭。模块应尽量在不修改原(是“原”,指原来的代码)代码的情况下进行扩展。迪米特法则(Law of Demeter)又叫作最少知识原则(Least Knowledge Principle 简写LKP),就是说一个对象应当对其他对象有尽可能少的了解,不和陌生人说话。依赖倒置原则A.高层次的模块不应该依赖于低层次的模块,他们都应该依赖于抽象。B.抽象不应该依赖于具体,具体应该依赖于抽象。?php /* * 外观模式 示例 * 为子系统中的一组接口提供一个一致的界面,定义一个高层接口,使得这一子系统更加的容易使用 */ class SubSytem1

    2、public function Method1() echo subsystem1 method1; class SubSytem2 public function Method2() echo subsystem2 method2; class SubSytem3 public function Method3() echo subsystem3 method3; class Facade private $_object1 = null; private $_object2 = null; private $_object3 = null; public function _constru

    3、ct() $this-_object1 = new SubSytem1(); $this-_object2 = new SubSytem2(); $this-_object3 = new SubSytem3(); public function MethodA() echo Facade MethodA; $this-_object1-Method1(); $this-_object2-Method2(); public function MethodB() echo Facade MethodB; $this-_object2-Method2(); $this-_object3-Method

    4、3(); / 实例化 $objFacade = new Facade(); $objFacade-MethodA(); $objFacade-MethodB();10.4外观模式可能你曾经有过在项目中集成第三方代码的经历。无论第三方代码是否面向对象,集成通常都是巨大而且复杂的工作,很容易让人畏缩。而对一个客户程序员来说,你的代码也可能是一个挑战,即使他可能仅需要访问很小一部分特性。外观模式可以为复杂系统创建一个简单、清晰的接口。10.4.1问题在系统中总会逐渐形成大量仅在系统自身内部有用的代码。系统也应该像类那样,提供定义清晰的公共接口,并对外隐藏内部结构。但是,系统中哪部分应该设置为公开,哪

    5、部分设置为隐藏并不容易决定。当使用子系统(如Web论坛或者图库)的代码时,你也许会发现自己过于深入地调用子系统的逻辑代码。如果子系统代码总是在不断变化,而你的代码却又在许多不同地方与子系统代码交互,那么随着子系统的发展,你也许会发现维护代码变得非常困难。类似地,当你创建自己的系统时,将不同的部分分层是很好的做法。例如,你可能会把系统分为应用逻辑层、数据库交互层和表现层等。你应该尽可能地使这些分层互相独立,以便项目中某一部分的修改尽量不影响到其他地方。如果某层中的代码与另一层的代码存在藕合的话,那么这个目标就很难达成了。下面是一些故意让人混淆的不着边际的程序代码,其功能只是从文件中获取log信息

    6、并将它转换为对象数据:function getProductFileLines($life)return file($file);function getProductObjectFromId($id, $productname)/一些数据库查询return new Product($id, $productname);function getNameFromLine($line)if(prep_match(“/.*-(.*)sd+/”,$line, $array)return str_replace (_, ,$array1);return ;function getIDFromLine($

    7、line) if(preg_match(“./(d1,3)-/”,$line,$array) return $array1; return -1;class Productpublic $id;public $name;function_ construct($id,$name)$this-id=$id;$this-name=$name;假设上面代码的内部其实是更复杂的,这样我们可以继续使用它们而非从头开始重写。我们的目的是将包含类似下面数据的文件转换为一个对象数组:234-ladies_jumper 55532-gents hat 44而我们必须调用所有这些方法(注意为了简单起见,我们并不计

    8、算出价格的最终数字):$lines=getProductFileLines(test.txt);$objects=array();foreach($lines as $line)$id=getIDFromLine($line);$name=getNameFromLine($line);$objects$id=getProductObjectFromID($id,$name);如果在项目中像这样直接调用这些方法,那么我们的代码会和子系统紧紧地祸合在一起。当子系统变化时,或者我们决定将其与子系统完全断开时,代码就会出问题。可见,我们需要在这些子系统和代码中引入一个入口。10.4.2实现下面这个简单

    9、的类为上面的过程式代码提供了一个接口:class ProductFacadeprivate $products=array();function _construct($file)$this-file=$file;$this-compile();private function compile()$lines=getProductFileLines($this-file);foreach($lines as $line)$id=getIDFromLine($line):$name=getNameFromLine($line);$this-products$id=getProduetObject

    10、FromID($id, $name);function getProducts()return $this-products;function getProduct($id)return $this-products$id;从客户端代码的角度来看,现在从一个log文件访问Product对象简单多了:$facade=new ProductFacade(test.txt);$facade-getProduct(234);/id=234的$name10.4.3效果外观模式是一个十分简单的概念,它只是为一个分层或一个子系统创建一个单一的入口。这会带来许多好处。首先,有助于分离项目中的不同部分。其次,对

    11、于客户端开发者来说,访问代码变得简洁,非常方便。另外,由于只在一个地方调用子系统,减少了出错的可能性,并因此可以预估子系统修改带来的问题所在。Facade类还能使客户端代码避免不正确地使用子系统中复杂的内部方法,从而减少错误的发生。外观模式:为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。它完美的体现了依赖倒转原则和迪米特法则的思想,所以是非常常用的模式之一。首先,在设计初期阶段,应该要有意识的将不同的两个层分离,例如经典三层架构,数据访问层、业务逻辑层、表示层,他们层与层之间建立外观 Facade,这样可以为复杂的子系统提供一个简单的接口

    12、,使得耦合大大降低。增加外观 Facade 可以提供一个简单的接口,减少它们之间的依赖。概述 外观模式,我们通过外观的包装,使应用程序只能看到外观对象,而不会看到具体的细节对象,这样无疑会降低应用程序的复杂度,并且提高了程序的可维护性。例子1:一个电源总开关可以控制四盏灯、一个风扇、一台空调和一台电视机的启动和关闭。该电源总开关可以同时控制上述所有电器设备,电源总开关即为该系统的外观模式设计。2. 问题为了降低复杂性,常常将系统划分为若干个子系统。但是如何做到各个系统之间的通信和相互依赖关系达到最小呢?3. 解决方案外观模式:为子系统中的一组接口提供一个一致的界面, Facade模式定义了一个

    13、高层接口,这个接口使得这一子系统更加容易使用。引入外观角色之后,用户只需要直接与外观角色交互,用户与子系统之间的复杂关系由外观角色来实现,从而降低了系统的耦合度。4. 适用性在遇到以下情况使用facade模式: 1) 当你要为一个复杂子系统提供一个简单接口时。子系统往往因为不断演化而变得越来越复杂。大多数模式使用时都会产生更多更小的类。 这使得子系统更具可重用性,也更容易对子系统进行定制,但这也给那些不需要定制子系统的用户带来一些使用上的困难。facade可以提供一个简单的缺省视图, 这一视图对大多数用户来说已经足够,而那些需要更多的可定制性的用户可以越过facade层。 2) 客户程序与抽象

    14、类的实现部分之间存在着很大的依赖性。引入 facade将这个子系统与客户以及其他的子系统分离,可以提高子系统的独立性 和可移植性。 3) 当你需要构建一个层次结构的子系统时,使用 facade模式定义子系统中每层的入口点。如果子系统之间是相互依赖的,你可以让它们仅通过facade进行通讯,从而简化了它们之间的依赖关系。5. 结构6.构建模式的组成外观角色(Facade):是模式的核心,他被客户client角色调用,知道各个子系统的功能。同时根据客户角色已有的需求预订了几种功能组合子系统角色(Subsystem classes):实现子系统的功能,并处理由Facade对象指派的任务。对子系统而言

    15、,facade和client角色是未知的,没有Facade的任何相关信息;即没有指向Facade的实例。客户角色(client):调用facade角色获得完成相应的功能。 7. 效果Facade模式有下面一些优点:1)对客户屏蔽子系统组件,减少了客户处理的对象数目并使得子系统使用起来更加容易。通过引入外观模式,客户代码将变得很简单,与之关联的对象也很少。2)实现了子系统与客户之间的松耦合关系,这使得子系统的组件变化不会影响到调用它的客户类,只需要调整外观类即可。3)降低了大型软件系统中的编译依赖性,并简化了系统在不同平台之间的移植过程,因为编译一个子系统一般不需要编译所有其他的子系统。一个子系

    16、统的修改对其他子系统没有任何影响,而且子系统内部变化也不会影响到外观对象。4)只是提供了一个访问子系统的统一入口,并不影响用户直接使用子系统类。Facade模式的缺点1) 不能很好地限制客户使用子系统类,如果对客户访问子系统类做太多的限制则减少了可变性和灵活性。2) 在不引入抽象外观类的情况下,增加新的子系统可能需要修改外观类或客户端的源代码,违背了“开闭原则”。8. 实现我们使用开关的例子;_light = new Light(); $this-_fan = new Fan(); $this-_ac = new AirConditioner(); $this-_tv = new Televi

    17、sion(); /* * 晚上开电灯 * */ public function method1($isOpen =1) if ($isOpen = 1) $this-_light-on(); $this-_fan-on(); $this-_ac-on(); $this-_tv-on(); else $this-_light-off(); $this-_fan-off(); $this-_ac-off(); $this-_tv-off(); /* * 白天不需要电灯 * */ public function method2() if ($isOpen = 1) $this-_fan-on();

    18、$this-_ac-on(); $this-_tv-on(); else $this-_fan-off(); $this-_ac-off(); $this-_tv-off(); /*子系统类 */ /* * */ class Light private $_isOpen = 0; public function on() echo Light is open, ; $this-_isOpen = 1; public function off() echo Light is off, ; $this-_isOpen = 0; class Fan private $_isOpen = 0; pub

    19、lic function on() echo Fan is open, ; $this-_isOpen = 1; public function off() echo Fan is off, ; $this-_isOpen = 0; class AirConditioner private $_isOpen = 0; public function on() echo AirConditioner is open, ; $this-_isOpen = 1; public function off() echo AirConditioner is off, ; $this-_isOpen = 0

    20、; class Television private $_isOpen = 0; public function on() echo Television is open, ; $this-_isOpen = 1; public function off() echo Television is off, ; $this-_isOpen = 0; /* * 客户类 * */ class client static function open() $f = new SwitchFacade(); $f-method1(1); static function close() $f = new Sw

    21、itchFacade(); $f-method1(0); client:open(); 11. 与其他相关模式 1)抽象工厂模式:Abstract Factory式可以与Facade模式一起使用以提供一个接口,这一接口可用来以一种子系统独立的方式创建子系统对象。 Abstract Factory也可以代替Facade模式隐藏那些与平台相关的类。 2)中介模式:Mediator模式与Facade模式的相似之处是,它抽象了一些已有的类的功能。然而,Mediator的目的是对同事之间的任意通讯进行抽象,通常集中不属于任何单个对象的功能。 Mediator的同事对象知道中介者并与它通信,而不是直接与其

    22、他同类对象通信。相对而言,Facade模式仅对子系统对象的接口进行抽象,从而使它们更容易使用;它并不定义新功能,子系统也不知道Facade的存在。 通常来讲,仅需要一个Facade对象,因此Facade对象通常属于Singleton模式。 3)Adapter模式: 适配器模式是将一个接口通过适配来间接转换为另一个接口。 外观模式的话,其主要是提供一个整洁的一致的接口给客户端。12. 总结1)根据“单一职责原则”,在软件中将一个系统划分为若干个子系统有利于降低整个系统的复杂性,一个常见的设计目标是使子系统间的通信和相互依赖关系达到最小,而达到该目标的途径之一就是引入一个外观对象,它为子系统的访问

    23、提供了一个简单而单一的入口。2)外观模式也是“迪米特法则”的体现,通过引入一个新的外观类可以降低原有系统的复杂度,外观类充当了客户类与子系统类之间的“第三者”,同时降低客户类与子系统类的耦合度。外观模式就是实现代码重构以便达到“迪米特法则”要求的一个强有力的武器。3)外观模式要求一个子系统的外部与其内部的通信通过一个统一的外观对象进行,外观类将客户端与子系统的内部复杂性分隔开,使得客户端只需要与外观对象打交道,而不需要与子系统内部的很多对象打交道。4)外观模式从很大程度上提高了客户端使用的便捷性,使得客户端无须关心子系统的工作细节,通过外观角色即可调用相关功能。5)不要试图通过外观类为子系统增加新行为 ,不要通过继承一个外观类在子系统中加入新的行为,这种做法是错误的。外观模式的用意是为子系统提供一个集中化和简化的沟通渠道,而不是向子系统加入新的行为,新的行为的增加应该通过修改原有子系统类或增加新的子系统类来实现,不能通过外观类来实现。何时选用外观模式 如果希望为一个复杂的子系统提供一个简单接口的时候,从而简化客户端的应用 如果希望客户端程序和抽象类实现松散耦合,可以考虑使用外观模式 如果构建多层结构的系统,可以松散各层结构之间的依赖关系。


    注意事项

    本文(外观模式.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开