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

    2023年-软件设计模式复习题.docx

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

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

    2023年-软件设计模式复习题.docx

    L简述“开一闭”原则的基本思想。请举出一个使用了软件“开一闭”原则的软件设计 模式,其中何处体现了 “开一闭”原则。答:“开一闭”原则:软件实体应当对扩展开放,而对修改关闭,“开-闭”原则要求软 件系统能够在不需要修改原有类的基础上,通过增加类达到扩展功能的目的。Abstract factory体现了这个原则,如果想增加一类新的products,只需在product类 体系中增加各个products,然后在factory类体系结构中增加一个concrete factory就可 以了,而不需要对现有类做任何修改,The Open-closed principleocp在不改动过模块源 代码的情况下扩展模块的行为。软件实体(类模块函数等)应该是可以扩展的,但是不可以修改的。2 .简述依赖例转原则的基本思想。请举出一个使用了软件依赖原则的软件设计模式,其 中何处体现了依赖原则。答:依赖倒置原则的基本思想是:高层模块不应该依赖于低层模块,二者都应该依赖 于抽象。抽象不应该依赖于细节,细节应该不依赖于抽象。Tomplate method就体现了这 个原则,它定义了一个操作中的算法骨架,而将一些步骤延迟到子类中,template method 使得子类不改变一个算法的结构,即可重定义该算法的某些特定步骤。3 .什么是单一职责原则?请举出一个使用了单一职责原则的软件设计模式,其中何处体 现了单一职责原则。答:基本思想:SRP使得一个类或一个模块承担的责任尽可能的少,使尽可能少的因素 或动机影响该类或该模块,即增大类或模块的内聚性,减少其耦合度,SRP是所有原则中最 简单的之一,也是最难正确运用的之一。COMMAND模式体现了 SRP原则,大多数类都是一组方法和相应的一组变量的结合,而该 模式只是封装了一个没有任何变量的函数,它对函数的关注超过了类,将一个请求封装为一 个对象,从而可用不同的请求对客户进行参数化。4 .软件复用可采用类的继承方式和类的聚合方式,比较两者的优缺点。答:聚合:一个对象拥有另一个对象或对另一个对象负责(即一个对象包含另一个对象 或是另一个对象的一部分)并且聚合对象和其所有具有相同的生命周期(即所谓的“同生共 死”关系)。聚合复用优点:容器类仅能通过被包含对象的接口来对其进行访问。“黑盒”复用, 因为被包含对象的内部细节对外是不可见。包装性好。实现上的相互依赖性比较小。 每一个类只专注于一项任务。通过获取指定其他的具有相同类型的对象的使用,可以在运 行期间动态地定义(对象的)组合。聚合的缺点:导致系统中的对象过多为了能将多个不同的对象作为组合块来使用, 必须仔细地对接口进行定义。类继承:是一种通过扩展(一个已有对象的)实现,从而获得新功能的复用方法。继承的优点:容易进行新的实现,因为其大多数可继承而来 易于修改或扩展那些被 复用的实现。继承的缺点:破坏了封装性,因为这会将父类的实现细节暴露给子类 “白盒”复用, 因为父类的内部细节对于子类而言通常是可见的当父类的实现更改时,子类也不得不随之 更改 从父类继承来的实现将不能在运行期间进行改变。5 .画出工厂方法模式的结构图。什么情况下适合使用工厂方发模式?MudCirnlor岫时漱用丽硼VF炯、岫加枫卿I财)其中product:为工厂模式所要创建的对象类型定义一个接口。Concrete product:实现 product 接口。Creator:声明工厂方法(factory method)返回值为product的一个对象。Concrete creator:覆写 factory Method (),返回值为 concrete product 的一个具体 实例。在下面情况下你可以考虑使用工厂方法模式:1)当客户程序不需要知道要使用对象的创建过程。2)客户程序使用的对象存在变动的可能,或者根本就不知道使用哪一个具体的对象。6 .画出合成模式(Composite)的结构图。举例说明一个可以应用合成模式的软件设计 实例,说明其中各角色的作用。实例:计算机和立体组合音响这样的设备经常被组装成一部分整体层次结构或者是容器 层次结构,例如:底盘可以包含驱动装置和平面板,总线含有多个插件,机柜包括底盘、总 线等。这样结构很自然的用composite模式进行模拟。Equipment类为在部分 整体层次结构中的所有设备定义一个接口。Equipment声明一 些操作返回一个设备的属性,例如它的能是消耗和价格。子类为指定的设备实现了这些操作, Equipment还声明了一个Create Iterator操作,该操作为访问它的零件返回一个Iterator , 这个操作的缺省实现返回一上Nulllterator,它在空集上迭代。Composite Equipment是包含其它设备的基类,它也是Equipment的子类。7 .简述门面模式(Facade)和中介者模式(Mediator)的基本思想,两者的差异何在?答:门面模式(facade)又称外观模式。基本思想:为子系统中的一组接口提供一个一 致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。“中介者模式”基本思想:Mediator Patten中文译为“中介者模式”、“调停者模式”。 调停者模式的定义是:用一个调停对象来封装一系列的对象交互。调停者使各对象不需要显 式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。简单点来说,将 原来两个直接引用或者依赖的对象拆开,在中间加入一个“调停”对象,使得两头的对象分 别和“调停”对象引用或者依赖。两者的差异:从目的上看,调停者模式与门面模式有些相似。但是门面模式是介于客 户程序与子系统之间的,而调停者模式是介于子系统与子系统之间的。这也注定了它们有很 大的区别:门面模式是将原有的复杂逻辑提取到一个统一的接口,简化客户对逻辑的使用。 它是被客户所感知的,而原有的复杂逻辑则被隐藏了起来。而调停者模式的加入并没有改变 客户原有的使用习惯,它是隐藏在原有逻辑后面的,使得代码逻辑更加清晰可用。8 .简述观察者模式的基本思想,如何实现当目标对象发生变化时多个观察者对象的同步 更新?画出他们之间的协作图。(1) Observer (观察者)基本思想:对象间的一种一对多的依赖关系。当一个对象的状 态发生变化时,所有依赖于它的对象都得到通知并自动更新。(2)协作:当Concrete Subject发生任何可能导到其参观者与其本身状态不一致的改 变时,它将通知它的各个观察者。在得到一个具体的目标改变通知后,Concrete Object对象可向目标对象查询信息,Concrete Object使用这个些信息以使它的状态与目标对象的状 态一致。(3)协作图: (3)协作图9 .举一适合使用State模式的例子。与不使用该模式相比,有哪些优点? 举例:抽象状态类定义了一个抽象方法“写程序”与不使用该模式相比优点:State模式将特定的状态相关的行为封装在一个类中,由于所有状态相关的代码都存在于某 个concrete state中,所以通过定义新的子类可以很容易的增加新的状态和转换。10 .有哪些模式的使用可以使得类的复用性增强?说明你的理由。策略模式(strategy)属于对象行为型模式,主要定义一系列的算法,把这些算法一个个封装成拥有共同接口的单独的类,并使他们之间互换,客户端调用他们的时候互不影响。算法使用和算法分离,即将变化的具体算法封装起来,降低了代码的耦合度,算法提取 起来,使算法得到重用。中介者模式(mediator) 用一个调停对象来封装一系列的对象交互。调停者使各对象 不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。即,将 原来的两个直接引用或者依赖的对象拆开,在中间加入一个“调停”对象,使得两头的对象 分别和“调停”对象引用或者依赖。提高了原有系统的可读性,将原有系统的多对多转化为 一对多,提高了代码的可复用性。适配器(Adapter)模式 是的原本由于接口不兼容而不能再一起的那些类可以一起工 作。如画图程序中,已实现绘制点,直线等功能。为了让客户程序在使用的时候不用关心不 同定义,定义个抽象类规范接口,当去实现绘图时,发现系统其它地方已有制图实现,但是 系统已有的方法与抽象类中规定方法不一样,这时候用适配器模式可以解决这问题。适配器 模式是为了面向接口编程中更好的复用。11 .比较Adapter和Proxy模式使用上的异同之处。适配器模式(Adapter):将一个类的接口转换成客户希望的另外一个接口。Adapter模式 使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。代理模式有两个英文名字:Proxy Pattern和Surrogate Pattern。代理模式:为其他 对象提供一种代理以控制对这个对象的访问。说白了就是,在一些情况下客户不想或者不能 直接引用一个对象,而代理对象可以在客户和目标对象之间起到中介作用,去掉客户不能看 到的内容和服务或者增添客户需要的额外服务。两者的主要区别在于代理模式应用的情况是不改变接口命名的,而且是对已有接口功能 的一种控制;而适配器模式则强调接口转换。12 .说明Observer模式的基本实现方式。如果不用该模式,要达到同样的效果,你会如 何做?观察者模式在关于目标角色、观察者角色通信的具体实现中,有两个版本。一种情况便是目标角色在发生变化后,仅仅告诉观察者角色“我变化了";观察者角色 如果想要知道具体的变化细节,则就要自己从目标角色的接口中得到。这种模式被很形象的 称为:拉模式一一就是说变化的信息是观察者角色主动从目标角色中“拉”出来的。还有一种方法,那就是我目标角色“服务一条龙”,通知你发生变化的同时,通过一个 参数将变化的细节传递到观察者角色中去。这就是“推模式”一一管你要不要,先给你啦。这两种模式的使用,取决于系统设计时的需要。如果目标角色比较复杂,并且观察者角 色进行更新时必须得到一些具体变化的信息,则“推模式”比较合适。如果目标角色比较简 单,则“拉模式”就很合适。如果不使用该模式,可采用策略模式,将不同的情况作为子类封装在一个类中,模拟 observer模式中目标角色的不同状态,当外部状态发生变化时,可以选择不同的strategy1、 strategy2改变观察者角色,从而达到与观察者模式同样的效果。13 .请列举一个使用装饰模式的例子。画出你的例子的类图结构。JUnit中的装饰模式:在JUnit中,TestCase是一个很重要的类,允许对其进行功能 扩展。在 junit. extensions 包中,TestDecorator、RepeatedTest 便是对 TestCase 的装 饰模式扩展。下面我们将它们和上面的角色对号入座。oRepeatedTesl14 .列举两个可以使我们在程序中不必使用ifelse结构的软件设计模式。使用软件设 计模式是如何做到这一点的?策略模式(strategy)和状态模式(state)策略模式是将不同算法(处理方法)封装到stategy类中,状态模式是将不同状态封装 到state类中。二者都是通过,类中的子类,实现不同情况的调用,从而有效的替换充满在 程序中的if else语句。15 .你认为在Linux平台上直接运行WIN32程序有可能吗?如认为不可能请说明理由; 如认为可能应如何实现这一目标?(1)两个OS内部实现有很大差别,甚至连路径的分隔符都不一样,一个WIN32程序无 论如何到了最后也要调用Window api,而这些api在linux上根本没有实现(2)例如:就 用户界面来说,有些windows的控件,在Linux上根本连对应的具有类似功能的控件都没有 怎么执行?如果再涉及进程,线程就更复杂了,差距也更大,如果想用一个Win32程序在linux 上执行,必须有一个间接层来缓和二者差距,然后要求WIN32程序只能调用这个间接层里面 的库函数16 . Java是一个跨平台的软件语言。为了实现跨平台,你认为采用哪种软件模式来实现 跨平台部分更合理?说明你的理由。答:abstract factory实现跨平台比较合适。用abstract factory提供一个高层接口, 来建造每个所需的Product,当然具体的实现要用Concrete factory来实现,然后让每个os 对应一个Concrete factory,这样当其它的Java类库需要平台支持时,只需调用abstract factory的相应函数即可,而无需关系它所在是什么平台。例如:用户界面awt这个类体系,它是跨平台的,它本身不能有绘制图形界面的代码,因 为这涉及具体的平台。所以它肯定要调用一个抽象工厂模式类的相应函数,具体实现就由 concrete factory 来负责。Bridge模式可以分离接口及其实现部分,使接口部分和实现部分可以独立变化,同时可 以对客户隐藏实现细节,实现bridge实现跨平台部分就有可能对不同的平台编写不同的具体 实现,而同时又保持接口部分java语言可以独立变化。

    注意事项

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

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




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

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

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

    收起
    展开