




已阅读5页,还剩31页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
郑州大学软件学院赵哲,1,软件体系结构,补充内容:第八章-面向对象体系结构设计原则,郑州大学软件学院赵哲,2,回顾,设计模式MVCABSDABSD相关术语ABSDM,郑州大学软件学院赵哲,3,本节主要内容,面向对象体系结构设计7大原则单一职责原则开-闭原则里氏代换原则依赖倒转原则接口隔离原则合成/聚合复用原则迪米特原则,郑州大学软件学院赵哲,4,单一职责原则,有关手机如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会削弱或抑制这个类完成其他职责的能力,这种耦合会导致脆弱的设计,当变化发生时,设计会遭受到意想不到的破坏!,郑州大学软件学院赵哲,5,单一职责原则,软件设计真正要做的许多内容,就是发现职责并且把职责相互分离原则:若想到多于一个的动机去改变一个类,那么这个类就具有多于一个的职责一个类只有一种职责SRPSingleResponsibilityPrinciple,郑州大学软件学院赵哲,6,开-闭原则,对扩展开放、对更改封闭OpenforextensionClosedformodification+-法类图,郑州大学软件学院赵哲,7,开-闭原则,开放-封闭原则是面向对象设计的核心所在遵循这个原则可以带来面向对象技术所声称的巨大好处开发人员将程序中呈现出频繁变化的部分抽象出来但是每个部分都进行抽象不是一个好主意。拒绝不成熟的抽象和抽象本身一样重要!,郑州大学软件学院赵哲,8,里氏代换原则,BarbaraLiskow在1988年发表的1972年Barbara成为麻省理工学院的教授是美国获得计算机科学博士学位的第一人,郑州大学软件学院赵哲,9,里氏代换原则,LiskowSubstitutionPrinciple(LSP):子类必须能够替换掉它们的父类型只要是基类出现的地方,一定能够出现子类!LSP指导继承,是继承的基石,郑州大学软件学院赵哲,10,LSP,例子:企鹅是一种鸟,鸟都会飞,但是企鹅不会飞,那么企鹅可以继承鸟这个类吗?不能!因为飞是鸟的public方法!一个例子:长方形和正方形某软件while(长=宽),将宽+1.父类没问题,但子类就回出现死循环正方形不可以继承长方形,郑州大学软件学院赵哲,11,LSP,例子孙悟空勾掉生死簿中所有猴子的名字,那么猕猴、石猴、长臂猿等的名字是否都勾掉了?乘马,乘白马、乘骊马注意LSP反之不成立!墨子小取娣,美人也,爱娣,非爱美人也.盗,人也;恶盗,非恶人也,郑州大学软件学院赵哲,12,依赖倒转原则,要针对接口编程,不要针对实现编程。Programtoaninterface,notanimplementation.电脑PC高层模块不应该依赖底层模块,两者应该都依赖抽象High-levelmoduleshouldnotdependuponbottommodule.bothshoulddependuponabstractions,郑州大学软件学院赵哲,13,依赖倒转原则,所谓的依赖倒转就是谁也不要依赖谁,除了约定的接口,大家都要灵活自在!收音机是否符合依赖倒转原则?为何说倒转呢?,郑州大学软件学院赵哲,14,为何说倒转,底层复用没关系,若要复用高层怎么办?,郑州大学软件学院赵哲,15,依赖倒转,无论是高层还是底层都不互相依赖高层模块不依赖底层模块,两者都应该依赖抽象。,郑州大学软件学院赵哲,16,依赖倒转的缺点,很强大,但却不多人会用需要丰富的面向对象经验和丰富的类管理经验,郑州大学软件学院赵哲,17,接口隔离原则,InterfaceSegregationPrincipleISP客户端不应该依赖它不需要的方法类间的依赖关系应该建立在最小的接口上,郑州大学软件学院赵哲,18,ISP,接口是我们设计时对外提供的契约,通过分散定义多个接口,可以预防未来变更的扩散,提高系统的灵活性和可维护性。接口定义的方法,在其子类必须要实现。一个例子一个接口:内容是雇佣者有吃饭和做工作的方法雇佣的男、女都可以使用该接口有一天,雇佣者来了一个机器人。机器人不吃饭,郑州大学软件学院赵哲,19,例子C#-错误,InterfaceIWorkervoideat();voidwork();ClassWorker:IWorkervoideat()/eat相关代码voidwork()/work相关代码,郑州大学软件学院赵哲,20,ISP,例子的缺陷胖接口,造成了对接口的污染如何解决?客户端不应该依赖它不需要的方法类间的依赖关系应该建立在最小的接口上一个接口只做一件事,郑州大学软件学院赵哲,21,例子C#-正确符合ISP,InterfaceIWorkerEatvoideat();InterfaceIWorkerWorkvoidwork();ClassWorker:IWorkerEat,IWorkerWorkvoideat()/eat相关代码voidwork()/work相关代码ClassRobot:IWorkerWorkvoidwork()/work相关代码,郑州大学软件学院赵哲,22,ISP,胖接口容易导致哑方法瘦接口更健康!,郑州大学软件学院赵哲,23,复习,单一职责原则一个类只做一件事开-闭原则对扩展开放,对修改关闭里氏代换原则只要基类出现的地方,都可以出现子类,郑州大学软件学院赵哲,24,复习,依赖倒转原则针对接口编程,不针对实现编程高层不依赖底层,两者都依赖抽象接口隔离原则客户端不依赖它不需要的方法瘦接口,郑州大学软件学院赵哲,25,合成/聚合复用原则,Composite/AggregateReusePrincipleCARP合成和聚合合成是强烈的关联,部分(将)和整体(主)生命周期一样,整体(主)对部分(将)有支配权,包括创建和销毁。聚合是部分和整体的普通关联,郑州大学软件学院赵哲,26,合成和聚合,刘邦和韩信,郑州大学软件学院赵哲,27,CARP原则,合成:classPersonprivateHandhand;publicPerson()hand=newHand();,郑州大学软件学院赵哲,28,CARP原则,聚合:classPersonprivateComputercomputer;publicsetComputer()computer=newComputer();,郑州大学软件学院赵哲,29,CARP原则,尽量使用合成/聚合,而不是使用继承继承的优点新的实现较为容易,因为基类的大部分功能可以通过继承的关系自动进入子类。修改和扩展继承而来的实现较为容易。继承的缺点继承将基类的实现细节暴露给子类。称“白箱”复用。如果基类发生改变,那么子类的实现也不得不发生改变。多继承不利于维护,郑州大学软件学院赵哲,30,CARP特定,优点:依赖少,条条框框的限制少几乎可以用到任何环境中容易实现修改和扩展容易缺点:对象多,需要管理,郑州大学软件学院赵哲,31,迪米特原则,TheLawofDemeterLoD想说爱你不容易不要和陌生人说话宅男/腐女记又叫最少知识原则,郑州大学软件学院赵哲,32,迪米特法则,一个对象应当对其他对象有尽可能少的了解,不和陌生人说话最少知识不相往来talkonlytoyourimmediatefriends,郑州大学软件学院赵哲,33,迪米特法则,郑州大学软件学院赵哲,34,迪米
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年二手电动摩托车环保材料研发与生产合同范本
- 2025年出口贸易货运代理全面服务合同
- 2025宾馆客房用品一站式采购及服务合同
- 2025标准个人医疗贷款合同范本
- 2025年度知识产权法律保护与维权服务合同范本
- 2025年度企业员工职业规划与就业指导合同
- 2025年度奢侈品导购员服务协议及销售提成合同
- 2025版教师综合素养与职业道德聘用合同
- 2025年单身公寓租赁合同编制指南
- 2025年度国有企业员工试用期劳动合同及福利
- 2025-2026秋季中小学第一学期升旗仪式22周校长演讲稿:第1周 烽火记忆照前路秋风为序启新程
- 2025秋人教部编版二年级上册语文教学计划
- 2025年山东省菏泽市中考英语真题(无答案)
- 2025劳动合同书示范文本下载
- 急性阑尾炎病人护理课件
- 水利水电工程单元工程施工质量验收标准第8部分:安全监测工程
- 2026年高考政治一轮复习:高考政治主观题背诵提纲汇编
- 骨科手术切口感染的预防与控制
- 电商数据分析报告顾问合同
- 电子信息类专业导论(第3版)课件全套 张有光 00 课程简介 - 12 中国大学教育:理念与实践
- 馕小屋管理办法
评论
0/150
提交评论