ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:118.48KB ,
资源ID:2838781      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/2838781.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(设计模式的六大原则实例优质文档.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

设计模式的六大原则实例优质文档.docx

1、设计模式的六大原则实例优质文档一、设计模式的六大原则1、开闭原则(Open Close Principle)开闭原则就是说对扩展开放,对修改关闭。在程序需要进行拓展的时候,不能去修改原有的代码,实现一个热插拔的效果。所以一句话概括就是:为了使程序的扩展性好,易于维护和升级。想要达到这样的效果,我们需要使用接口和抽象类。开闭原则是面向对象的可复用设计的第一块基石。开闭原则的关键是抽象化。2、里氏代换原则(Liskov Substitution Principle)里氏代换原则(Liskov Substitution Principle LSP)面向对象设计的基本原则之一。 里氏代换原则中说,任何

2、基类可以出现的地方,子类一定可以出现。 LSP是继承复用的基石,只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用,而衍生类也能够在基类的基础上增加新的行为。里氏代换原则是对“开-闭”原则的补充。实现“开-闭”原则的关键步骤就是抽象化。而基类与子类的继承关系就是抽象化的具体实现,所以里氏代换原则是对实现抽象化的具体步骤的规范。面向对象的设计关注的是对象的行为,它是使用“行为”来对对象进行分类的,只有行为一致的对象才能抽象出一个类来。我经常说类的继承关系就是一种“Is-A”关系,实际上指的是行为上的“Is-A”关系,可以把它描述为“Act-As”。3、依赖倒转原则(Dep

3、endence Inversion Principle)这个是开闭原则的基础,具体内容:真对接口编程,依赖于抽象而不依赖于具体。4、接口隔离原则(Interface Segregation Principle)这个原则的意思是:使用多个隔离的接口,比使用单个接口要好。还是一个降低类之间的耦合度的意思,从这儿我们看出,其实设计模式就是一个软件的设计思想,从大型软件架构出发,为了升级和维护方便。所以上文中多次出现:降低依赖,降低耦合。5、迪米特法则(最少知道原则)(Demeter Principle)最少知道原则,就是说:一个实体应当尽量少的与其他实体之间发生相互作用,使得系统功能模块相对独立。6

4、、合成复用原则(Composite Reuse Principle)合成/聚合复用原则是在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过向这些对象的委派达到复用已有功能的目的。合成(Composition)和聚合(Aggregation)都是关联(Association)的特殊种类。原则是尽量使用合成/聚合的方式,而不是使用继承。11.开闭原则实例Fruit接口:抽象产品Orange类:实现fruit接口,具体产品Apple类:实现Fruit接口,具体产品Gardener接口:抽象工厂AppleGardener类:实现Gardener接口,具体工厂,分管apple生产

5、OrangeGardener类:实现Gardener接口,具体工厂,分管orange生产package com.zky.www.factory;public interface Fruit /水果接口 public void plant(); public void grow(); public void harvest();public class Apple implements Fruit /苹果实现水果接口 public void grow() System.out.println(apple is growing!); public void harvest() System.out

6、.println(apple is harvesting!); public void plant() System.out.println(apple is planting!); public class Orange implements Fruit /桔子实现水果接口 public void grow() System.out.println(orange is growing!); public void harvest() System.out.println(orange is harvesting!); public void plant() System.out.printl

7、n(orange is planting!); public interface Gardener /园丁接口 public Fruit getFruit();public class AppleGardener implements Gardener Override public Fruit getFruit() return new Apple(); public class OrangeGradener implements Gardener Override public Fruit getFruit() return new Orange(); public class Clien

8、t public static void main(String args) Gardener g1=new AppleGardener(); Apple apple=(Apple) g1.getFruit(); apple.harvest(); 22、里氏代换原则实例正方形不是长方形package com.zky.www.liskov;public class Rectangle private double width; private double height; public Rectangle() public Rectangle(double width, double heigh

9、t) super(); this.width = width; this.height = height; public double getWidth() return width; public void setWidth(double width) this.width = width; public double getHeight() return height; public void setHeight(double height) this.height = height; package com.zky.www.liskov;public class Square exten

10、ds Rectangle private double side; public Square(double side) super(); this.side = side; public double getSide() return side; public void setSide(double side) this.side = side; package com.zky.www.liskov;public class SmartTest public void resize(Rectangle r) while (r.getHeight()=r.getWidth() r.setWid

11、th(r.getWidth()+1); 33、依赖倒转原则实例publicclassBenz /汽车肯定会跑 publicvoidrun() System.out.println(奔驰汽车开始运行.); publicclassDriver /司机的主要职责就是驾驶汽车 publicvoiddrive(Benz benz) benz.run(); publicclassClient publicstaticvoidmain(String args) Driver zhangSan = newDriver(); Benz benz = newBenz(); /张三开奔驰车 zhangSan.dri

12、ve(benz); 上面实例,司机张三只能开奔驰车,不能开其他车,因此设计出了问题,改正如下。publicinterfaceIDriver /是司机就应该会驾驶汽车 publicvoiddrive(ICar car); publicclassDriver implementsIDriver /司机的主要职责就是驾驶汽车 publicvoiddrive(ICar car) car.run(); publicinterfaceICar /是汽车就应该能跑 publicvoidrun(); publicclassBenz implementsICar /汽车肯定会跑 publicvoidrun()

13、System.out.println(奔驰汽车开始运行.); publicclassBMW implementsICar /宝马车当然也可以开动了 publicvoidrun() System.out.println(宝马汽车开始运行.); 在业务场景中,我们贯彻“抽象不应该依赖细节”,也就是我们认为抽象(ICar接口)不依赖BMW和Benz两个实现类(细节),因此我们在高层次的模块中应用都是抽象,Client的实现过程如下:public class Client public static void main(String args) IDriver zhangSan = new Drive

14、r();ICar benz = new Benz();/张三开奔驰车zhangSan.drive(benz); Client属于高层业务逻辑,它对低层模块的依赖都建立在抽象上,zhangSan的显示类型是IDriver,benz的显示类型是ICar,也许你要问,在这个高层模块中也调用到了低层模块,比如new Driver()和new Benz()等,如何解释?确实如此,zhangSan的显示类型是IDriver,是一个接口,是抽象的,非实体化的,在其后的所有操作中,zhangSan都是以IDriver类型进行操作,屏蔽了细节对抽象的影响。当然,张三如果要开宝马车,也很容易,我们只要修改业务场景类就可以。注意在Java中,只要定义变量就必然要有类型,一个变量可以有两

copyright@ 2008-2022 冰豆网网站版权所有

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