欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    2022年程序设计七大原则 .pdf

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

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

    2022年程序设计七大原则 .pdf

    软件设计的七大原则设计模式遵循的一般原则:1.开-闭原则 (Open-Closed Principle, OCP):一个软件实体应当对扩展开发 ,对修改关闭 .说的是 ,再设计一个模块的时候 ,应当使这个模块可以在不被修改的前提下被扩展 .换言之 ,应当可以在不必修改源代码的情况下改变这个模块的行为,在保持系统一定稳定性的基础上,对系统进行扩展。这是面向对象设计(OOD )的基石,也是最重要的原则。2.里氏代换原则 (Liskov Substitution Principle, 常缩写为.LSP) (1).由 Barbar Liskov(芭芭拉 .里氏)提出,是继承复用的基石。(2).严格表达 :如果每一个类型为T1 的对象 o1,都有类型为 T2 的对象 o2,使得以 T1 定义的所有程序P 在所有的对象 o1 都代换称 o2 时,程序 P 的行为没有变化 ,那么类型 T2 是类型 T1的子类型 . 换言之 ,一个软件实体如果使用的是一个基类的话,那么一定适用于其子类,而且它根本不能察觉出基类对象和子类对象的区别.只有衍生类可以替换基类,软件单位的功能才能不受影响, 基类才能真正被复用,而衍生类也能够在基类的基础上增加新功能。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 8 页 - - - - - - - - - (3).反过来的代换不成立(4). 中说:白马,马也; 乘白马 ,乘马也 .骊马(黑马),马也;乘骊马 ,乘马也 . (5).该类西方著名的例程为:正方形是否是长方形的子类(答案是 否)。类似的还有椭圆和圆的关系。(6). 应当尽量从抽象类继承,而不从具体类继承,一般而言,如果有两个具体类A,B 有继承关系 ,那么一个最简单的修改方案是建立一个抽象类C,然后让类 A 和 B成为抽象类C 的子类.即如果有一个由继承关系形成的登记结构的话,那么在等级结构的树形图上面所有的树叶节点都应当是具体类;而所有的树枝节点都应当是抽象类或者接口 . (7).基于契约设计 (Design By Constract), 简称 DBC这项技术对LISKOV 代换原则提供了支持.该项技术Bertrand Meyer 伯特兰做过详细的介绍 : 使用 DBC,类的编写者显式地规定针对该类的契约.客户代码的编写者可以通过该契约获悉可以依赖的行为方 式 . 契 约 是 通 过 每 个 方 法 声 明 的 前 置 条 件(preconditions) 和后置条件 (postconditions) 来指定的 .要使一个方法得以执行,前置条件必须为真 .执行完毕后,该方法要保证后置条件为真.就是说 ,在重新声明派生类中的例程(routine) 时,只能使用相等或者更弱的名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 8 页 - - - - - - - - - 前置条件来替换原始的前置条件,只能使用相等或者更强的后置条件来替换原始的后置条件. 3.依赖倒置原则 (Dependence Inversion Principle), 要求客户端依赖于抽象耦合. (1)表述 :抽象不应当依赖于细节,细节应当依赖于抽象.(Program to an interface, not an implementaction) (2)表述二 :针对接口编程的意思是说,应当使用接口和抽象类进行变量的类型声明,参量的类型声明 ,方法的返还类型声明 ,以及数据类型的转换等.不要针对实现编程的意思就是说,不应当使用具体类进行变量的类型声明 ,参量类型声明 ,方法的返还类型声明 ,以及数据类型的转换等 . 要保证做到这一点 ,一个具体的类应等只实现接口和抽象类中声明过的方法,而不应当给出多余的方法. 只要一个被引用的对象存在抽象类型,就应当在任何引用此对象的地方使用抽象类型,包括参量的类型声明,方法返还类型的声明 ,属性变量的类型声明等 . (3) 接口与抽象的区别就在于抽象类可以提供某些方法的部分实现 ,而接口则不可以 ,这也大概是抽象类唯一的优点 .如果向一个抽象类加入一个新的具体方法,名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 8 页 - - - - - - - - - 那么所有的子类型一下子就都得到得到了这个新的具体方法 ,而接口做不到这一点.如果向一个接口加入了一个新的方法的话,所有实现这个接口的类就全部不能通过编译了 ,因为它们都没有实现这个新声明的方法.这显然是接口的一个缺点 . (4)一个抽象类的实现只能由这个抽象类的子类给出,也就是说 ,这个实现处在抽象类所定义出的继承的登记结构中 ,而由于一般语言都限制一个类只能从最多一个超类继承 ,因此将抽象作为类型定义工具的效能大打折扣 . 反过来 ,看接口 ,就会发现任何一个实现了一个接口所规定的方法的类都可以具有这个接口的类型,而一个类可以实现任意多个接口. (5)从代码重构的角度上讲,将一个单独的具体类重构成一个接口的实现是很容易的,只需要声明一个接口,并将重要的方法添加到接口声明中,然后在具体类定义语句中加上保留字以继承于该接口就行了. 而作为一个已有的具体类添加一个抽象类作为抽象类型不那么容易,因为这个具体类有可能已经有一个超类 .这样一来 ,这个新定义的抽象类只好继续向上移动,变成这个超类的超类 ,如此循环 ,最后这个新的抽象类必定处于整个类型等级结构的最上端,从而使登名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 8 页 - - - - - - - - - 记结构中的所有成员都会受到影响. (6)接口是定义混合类型的理想工具,所为混合类型 ,就是在一个类的主类型之外的次要类型.一个混合类型表明一个类不仅仅具有某个主类型的行为,而且具有其他的次要行为 . (7)联合使用接口和抽象类 : 由于抽象类具有提供缺省实现的优点,而接口具有其他所有优点 ,所以联合使用两者就是一个很好的选择. 首先 ,声明类型的工作仍然接口承担的,但是同时给出的还有一个抽象类,为这个接口给出一个缺省实现.其他同属于这个抽象类型的具体类可以选择实现这个接口 ,也可以选择继承自这个抽象类.如果一个具体类直接实现这个接口的话,它就必须自行实现所有的接口 ;相反,如果它继承自抽象类的话,它可以省去一些不必要的的方法,因为它可以从抽象类中自动得到这些方法的缺省实现;如果需要向接口加入一个新的方法的话 ,那么只要同时向这个抽象类加入这个方法的一个具体实现就可以了,因为所有继承自这个抽象类的子类都会从这个抽象类得到这个具体方法.这其实就是缺省适配器模式 (Defaule Adapter). (8)什么是高层策略呢 ?它是应用背后的抽象 ,是那些不名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 8 页 - - - - - - - - - 随具体细节的改变而改变的真理. 它是系统内部的系统_隐喻. 4.接口隔离原则 (Interface Segregation Principle, ISP) (1) 一个类对另外一个类的依赖是建立在最小的接口上。(2)使用多个专门的接口比使用单一的总接口要好.根据客户需要的不同,而为不同的客户端提供不同的服务是一种应当得到鼓励的做法.就像看人下菜碟 一样,要看客人是谁 ,再提供不同档次的饭菜 . (3)胖接口会导致他们的客户程序之间产生不正常的并且有害的耦合关系.当一个客户程序要求该胖接口进行一个改动时,会影响到所有其他的客户程序.因此客户程序应该仅仅依赖他们实际需要调用的方法. 5. 合成 / 聚合复 用原则 (Composite/Aggregate Reuse Principle,CARP) 在一个新的对象里面使用一些已有的对象,使之成为新对象的一部分;新的对象通过这些向对象的委派达到复用已有功能的目的.这个设计原则有另一个简短的表述 :要尽量使用合成 /聚合,尽量不要使用继承 . 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 8 页 - - - - - - - - - 6.迪米特法则 (Law of Demeter LoD)又叫做最少知识原则(Least Knowledge Principle,LKP),就是说 ,一个对象应当对其他对象有尽可能少的了了解. 迪米特法则最初是用来作为面向对象的系统设计风格的一种法则 ,与1987 年秋天由 Ian Holland 在美国东北大学为一个叫做迪米特(Demeter) 的项目设计提出的 ,因此叫做迪米特法则LIEB89LIEB86. 这条法则实际上是很多著名系统,比如火星登陆软件系统,木星的欧罗巴卫星轨道飞船的软件系统的指导设计原则. 没有任何一个其他的OO 设计原则象迪米特法则这样有如此之多的表述方式 ,如下几种 : (1)只 与 你 直 接 的 朋 友 们通 信 (Only talk to your immediate friends) (2)不要跟 陌生人 说话(Dont talk to strangers) (3)每一个软件单位对其他的单位都只有最少的知识,而且局限于那些本单位密切相关的软件单位. 就是说 ,如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用,如果其中的一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 8 页 - - - - - - - - - 7.单一职责原则 (Simple responsibility pinciple SRP) 就一个类而言 ,应该仅有一个引起它变化的原因,如果你能想到多于一个的动机去改变一个类,那么这个类就具有多于一个的职责.应该把多于的指责分离出去,分别再创建一些类来完成每一个职责. 另外:常说的 OO 五大原则就是指其中的:1、单一职责原则; 2、开放闭合原则; 3、里氏替换原则; 4、依赖倒置原则; 5、接口隔离原则。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 8 页 - - - - - - - - -

    注意事项

    本文(2022年程序设计七大原则 .pdf)为本站会员(H****o)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

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




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开