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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

软件设计模式复习题.docx

1、软件设计模式复习题1.简述“开闭”原则的差不多思想。请举出一个使用了软件“开闭”原则的软件设计模式,其中何处体现了“开闭”原则。答:“开闭”原则:软件实体应当对扩展开放,而对修改关闭,“开-闭”原则要求软件系统能够在不需要修改原有类的基础上,通过增加类达到扩展功能的目的。Abstract factory体现了那个原则,假如想增加一类新的products,只需在product类体系中增加各个products,然后在factory类体系结构中增加一个concrete factory就能够了,而不需要对现有类做任何修改,The Open-closed principleocp在不改动过模块源代码的情

2、况下扩展模块的行为。软件实体(类模块 函数等)应该是能够扩展的,然而不能够修改的。2.简述依靠例转原则的差不多思想。请举出一个使用了软件依靠原则的软件设计模式,其中何处体现了依靠原则。答:依靠倒置原则的差不多思想是:高层模块不应该依靠于低层模块,二者都应该依靠于抽象。抽象不应该依靠于细节,细节应该不依靠于抽象。Tomplate method就体现了那个原则,它定义了一个操作中的算法骨架,而将一些步骤延迟到子类中,template method使得子类不改变一个算法的结构,即可重定义该算法的某些特定步骤。 3.什么是单一职责原则?请举出一个使用了单一职责原则的软件设计模式,其中何处体现了单一职责

3、原则。答:差不多思想:SRP使得一个类或一个模块承担的责任尽可能的少,使尽可能少的因素或动机阻碍该类或该模块,即增大类或模块的内聚性,减少其耦合度,SRP是所有原则中最简单的之一,也是最难正确运用的之一。COMMAND模式体现了SRP原则,大多数类差不多上一组方法和相应的一组变量的结合,而该模式只是封装了一个没有任何变量的函数,它对函数的关注超过了类,将一个请求封装为一个对象,从而可用不同的请求对客户进行参数化。4.软件复用可采纳类的继承方式和类的聚合方式,比较两者的优缺点。答:聚合:一个对象拥有另一个对象或对另一个对象负责(即一个对象包含另一个对象或是另一个对象的一部分)同时聚合对象和其所有

4、具有相同的生命周期(即所谓的“同生共死”关系)。聚合复用优点:容器类仅能通过被包含对象的接口来对其进行访问。“黑盒”复用,因为被包含对象的内部细节对外是不可见。包装性好。实现上的相互依靠性比较小。每一个类只专注于一项任务。通过猎取指定其他的具有相同类型的对象的使用,能够在运行期间动态地定义(对象的)组合。聚合的缺点:导致系统中的对象过多 为了能将多个不同的对象作为组合块来使用,必须认真地对接口进行定义。类继承:是一种通过扩展(一个已有对象的)实现,从而获得新功能的复用方法。继承的优点:容易进行新的实现,因为其大多数可继承而来 易于修改或扩展那些被复用的实现。继承的缺点:破坏了封装性,因为这会将

5、父类的实现细节暴露给子类 “白盒”复用,因为父类的内部细节关于子类而言通常是可见的 当父类的实现更改时,子类也不得不随之更改 从父类继承来的实现将不能在运行期间进行改变。5.画出工厂方法模式的结构图。什么情况下适合使用工厂方发模式?其中product:为工厂模式所要创建的对象类型定义一个接口。Concrete product:实现product接口。Creator:声明工厂方法(factory method)返回值为product的一个对象。Concrete creator:覆写factory Method(),返回值为concrete product 的一个具体实例。在下面情况下你能够考虑使

6、用工厂方法模式: 1) 当客户程序不需要明白要使用对象的创建过程。 2) 客户程序使用的对象存在变动的可能,或者全然就不明白使用哪一个具体的对象。6.画出合成模式(Composite)的结构图。举例讲明一个能够应用合成模式的软件设计实例,讲明其中各角色的作用。实例:计算机和立体组合音响如此的设备经常被组装成一部分整体层次结构或者是容器层次结构,例如:底盘能够包含驱动装置和平面板,总线含有多个插件,机柜包括底盘、总线等。如此结构专门自然的用composite模式进行模拟。Equipment类为在部分整体层次结构中的所有设备定义一个接口。Equipment声明一些操作返回一个设备的属性,例如它的能

7、是消耗和价格。子类为指定的设备实现了这些操作,Equipment还声明了一个Create Iterator 操作,该操作为访问它的零件返回一个Iterator ,那个操作的缺省实现返回一上NullIterator,它在空集上迭代。Composite Equipment是包含其它设备的基类,它也是Equipment的子类。7.简述门面模式(Facade)和中介者模式(Mediator)的差不多思想,两者的差异何在?答:门面模式(facade)又称外观模式。差不多思想:为子系统中的一组接口提供一个一致的界面, Facade模式定义了一个高层接口,那个接口使得这一子系统更加容易使用。“中介者模式”差

8、不多思想:Mediator Pattern 中文译为“中介者模式”、“调停者模式”。调停者模式的定义是:用一个调停对象来封装一系列的对象交互。调停者使各对象不需要显式地相互引用,从而使其耦合松散,而且能够独立地改变它们之间的交互。简单点来讲,将原来两个直接引用或者依靠的对象拆开,在中间加入一个“调停”对象,使得两头的对象分不和“调停”对象引用或者依靠。两者的差异: 从目的上看,调停者模式与门面模式有些相似。 然而门面模式是介于客户程序与子系统之间的,而调停者模式是介于子系统与子系统之间的。这也注定了它们有专门大的区不:门面模式是将原有的复杂逻辑提取到一个统一的接口,简化客户对逻辑的使用。它是被

9、客户所感知的,而原有的复杂逻辑则被隐藏了起来。而调停者模式的加入并没有改变客户原有的使用适应,它是隐藏在原有逻辑后面的,使得代码逻辑更加清晰可用。8.简述观看者模式的差不多思想,如何实现当目标对象发生变化时多个观看者对象的同步更新?画出他们之间的协作图。(1)Observer(观看者)差不多思想:对象间的一种一对多的依靠关系。当一个对象的状态发生变化时,所有依靠于它的对象都得到通知并自动更新。(2)协作:当Concrete Subject发生任何可能导到其参观者与其本身状态不一致的改变时,它将通知它的各个观看者。在得到一个具体的目标改变通知后,Concrete Object对象可向目标对象查询

10、信息,Concrete Object使用那个些信息以使它的状态与目标对象的状态一致。(3)协作图:9.举一适合使用State模式的例子。与不使用该模式相比,有哪些优点?举例:抽象状态类定义了一个抽象方法“写程序”与不使用该模式相比优点:State模式将特定的状态相关的行为封装在一个类中,由于所有状态相关的代码都存在于某个concrete state中,因此通过定义新的子类能够专门容易的增加新的状态和转换。10.有哪些模式的使用能够使得类的复用性增强?讲明你的理由。策略模式(strategy) 属于对象行为型模式,要紧定义一系列的算法,把这些算法一个个封装成拥有共同接口的单独的类,并使他们之间互

11、换,客户端调用他们的时候互不阻碍。算法使用和算法分离,立即变化的具体算法封装起来,降低了代码的耦合度,算法提取起来,使算法得到重用。中介者模式(mediator) 用一个调停对象来封装一系列的对象交互。调停者使各对象不需要显式地相互引用,从而使其耦合松散,而且能够独立地改变它们之间的交互。即,将原来的两个直接引用或者依靠的对象拆开,在中间加入一个“调停”对象,使得两头的对象分不和“调停”对象引用或者依靠。提高了原有系统的可读性,将原有系统的多对多转化为一对多,提高了代码的可复用性。适配器(Adapter)模式 是的原本由于接口不兼容而不能再一起的那些类能够一起工作。如画图程序中,已实现绘制点,

12、直线等功能。为了让客户程序在使用的时候不用关怀不同定义,定义个抽象类规范接口,当去实现绘图时,发觉系统其它地点已有制图实现,然而系统已有的方法与抽象类中规定方法不一样,这时候用适配器模式能够解决这问题。适配器模式是为了面向接口编程中更好的复用。11.比较Adapter和Proxy模式使用上的异同之处。适配器模式(Adapter):将一个类的接口转换成客户希望的另外一个接口。Adapter 模式使得原本由于接口不兼容而不能一起工作的那些类能够一起工作。代理模式有两个英文名字:Proxy Pattern 和 Surrogate Pattern。代理模式:为其他对象提供一种代理以操纵对那个对象的访问

13、。讲白了确实是,在一些情况下客户不想或者不能直接引用一个对象,而代理对象能够在客户和目标对象之间起到中介作用,去掉客户不能看到的内容和服务或者增添客户需要的额外服务。两者的要紧区不在于代理模式应用的情况是不改变接口命名的,而且是对已有接口功能的一种操纵;而适配器模式则强调接口转换。 12.讲明Observer模式的差不多实现方式。假如不用该模式,要达到同样的效果,你会如何做?观看者模式在关于目标角色、观看者角色通信的具体实现中,有两个版本。一种情况便是目标角色在发生变化后,仅仅告诉观看者角色“我变化了”;观看者角色假如想要明白具体的变化细节,则就要自己从目标角色的接口中得到。这种模式被专门形象

14、的称为:拉模式确实是讲变化的信息是观看者角色主动从目标角色中“拉”出来的。 还有一种方法,那确实是我目标角色“服务一条龙”,通知你发生变化的同时,通过一个参数将变化的细节传递到观看者角色中去。这确实是“推模式”管你要不要,先给你啦。 这两种模式的使用,取决于系统设计时的需要。假如目标角色比较复杂,同时观看者角色进行更新时必须得到一些具体变化的信息,则“推模式”比较合适。假如目标角色比较简单,则“拉模式”就专门合适。 假如不使用该模式,可采纳策略模式,将不同的情况作为子类封装在一个类中,模拟observer模式中目标角色的不同状态,当外部状态发生变化时,能够选择不同的strategy1、stra

15、tegy2改变观看者角色,从而达到与观看者模式同样的效果。13.请列举一个使用装饰模式的例子。画出你的例子的类图结构。JUnit 中的装饰模式:在 JUnit 中,TestCase 是一个专门重要的类,同意对其进行功能扩展。 在 junit.extensions 包中,TestDecorator、RepeatedTest 便是对 TestCase 的装饰模式扩展。下面我们将它们和上面的角色对号入座。14.列举两个能够使我们在程序中不必使用ifelse结构的软件设计模式。使用软件设计模式是如何做到这一点的?策略模式(strategy)和状态模式(state)策略模式是将不同算法(处理方法)封装到

16、stategy类中,状态模式是将不同状态封装到state类中。二者差不多上通过,类中的子类,实现不同情况的调用,从而有效的替换充满在程序中的 if else 语句。15.你认为在Linux平台上直接运行WIN32程序有可能吗?如认为不可能请讲明理由;如认为可能应如何实现这一目标?(1)两个OS内部实现有专门大差不,甚至连路径的分隔符都不一样,一个WIN32程序不管如何到了最后也要调用Window api,而这些api在linux上全然没有实现(2)例如:就用户界面来讲,有些windows的控件,在Linux上全然连对应的具有类似功能的控件都没有如何执行?假如再涉及进程,线程就更复杂了,差距也更

17、大,假如想用一个win32程序在linux上执行,必须有一个间接层来缓和二者差距,然后要求WIN32程序只能调用那个间接层里面的库函数16. Java是一个跨平台的软件语言。为了实现跨平台,你认为采纳哪种软件模式来实现跨平台部分更合理?讲明你的理由。答:abstract factory实现跨平台比较合适。用abstract factory提供一个高层接口,来建筑每个所需的Product,因此具体的实现要用Concrete factory来实现,然后让每个os对应一个Concrete factory,如此当其它的Java类库需要平台支持时,只需调用abstract factory的相应函数即可,而无需关系它所在是什么平台。例如:用户界面awt那个类体系,它是跨平台的,它本身不能有绘制图形界面的代码,因为这涉及具体的平台。因此它确信要调用一个抽象工厂模式类的相应函数,具体实现就由concrete factory来负责。Bridge模式能够分离接口及事实上现部分,使接口部分和实现部分能够独立变化,同时能够对客户隐藏实现细节,实现bridge实现跨平台部分就有可能对不同的平台编写不同的具体实现,而同时又保持接口部分java语言能够独立变化。

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

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