UML、设计模式(测试题)

不定项选择题:

1.一个软件产品是否成功,因素有(        )。

l         需求收集是否正确

l         体系结构的构建是否合理

l         测试是否完全

l         软件的管理

2.开发过程中最困难的一个环节是(        )。

人与人之间的交流    

3.用例是从(   用户    )的观点对系统行为的一个描述。

4.顺序图所表达的是基于(    时间顺序    )的动态交互。

5.当需要在项目中定制自己的元素时,可使用(    构造型来定制    )。

6.表示一个操作中的参数和返回值的数据类型的称呼是(  形构      )。

7.多重性510表示(    5或者10    )。

8.在找出了类的继承关系后,通常可以用(   接口     )来表示最上层的基类。

9UML中的实现是一种特殊类型的继承,因为它是指从一个(     接口   )继承。

10.使用用例的难点在于(   用例中各个场景的具体步骤    )。

11.收集用例的方法是(    交谈    )。

12.产生类图和得到用例这两个步骤,位于前面的是(  没有固定顺序      )。

13.面向对象理论中,对象之间发送信号,在UML状态图里就是(   事件     )。

14.顺序图中,动态创建对象表示法的特点是(是在时间线上的某一点创建,结束时尾部打X)。

15.当代软件工程的特点是(        )。

l         允许各个阶段进行迭代

l         各个阶段没有明显的分界线

l         允许后期得到的信息返回,使得早期的能够被修改。

16GRAPPLE

中最重要的段是(        )。

l         需求收集

l         需求分析

l         用例开发

l         编码

l         测试

17.设计模式的基本要素有(   名称,目的(意图),解决方案,实施后达到的效果     )。

18.当我们想创建一个具体的对象而又不希望指定具体的类时,可以使用(    创建性    )模式。

19.当我们想将抽象部分和实现部分分离时,可以使用(    桥接    )模式。

20.当我们想用不同的请求对客户进行参数化时,可以使用(    命令    )模式。

21.当我们想封装不同算法并使它们可相互替换时,可以使用(      策略  )模式。

22面向对象系统中功能复用的两种最常用技术是(        )。

l         对象组合(优先使用)

l         类继承(限制使用类继承)->产生类爆炸

23.面向对象系统中的“黑盒复用”是指(    对象组合    )。

24对象组合是通过获得(    抽象类的指针    )而在运行时刻动态定义的。

25.设计模式中应优先使用的复用技术是(    对象组合    )。

26.在Lexi系统中,我们把所有文档元素都看作是图元,这样,它们就有了相同的(   接口(也叫类型)     )。

27Lexi系统中,我们之所以能对文档采用Composite模式,是因为文档的元素之间有

    递归 (树型结构)   )关系。

 

 

 

填空题:

1.软件体系结构是指一个系统的有目的的设计和规划,这个设计规划既不描述    活动    ,也不描述        系统怎样开发      ,它只描述系统的      组成元素    及其相互的     交互协作       

2.一个UML模型只描述了一个系统     要做什么       ,它并没告诉我们系统是             么做         

3.接口是可以在整个模型中反复使用的一组行为,是一个没有   属性     而只有  方法      的类。

4.多重性指的是,某个类有       多个   个对象可以和另一个类的       1    对象关联。

5.当一个类的对象可以充当多种角色时,      自身    关联就可能发生。

6.在泛化关系中,    子类    可以替代  父类      。也就是说,后者出现的地方,前者都可以出现。但是反过来却不成立。

7.最通常的依赖关系是一个类操作的    形构      中用到了     另一个类         的定义。

8.组成是    强类型      的聚集,因为聚集中的每个部分体只能属于     一个     整体。

9.实现的符号和继承的符号有相似之处,两者的唯一差别是实现关系用   虚线       表示,继承关系用        实线    表示。

10UML背后的两个重量级概念是    用例               面向对象           

11.状态图和类图、顺序图不同之处在于,后两种图能够对     多个对象                  建立模型,而状态图只是对       1个对象        建立模型。

12.状态图中3个常用的动作是       入口动作             出口动                 do动作,也就是对象处于这个状态时应该做什么      

13.顺序图中,消息用         水平箭头线         表示;时间用   垂直虚线                  表示。

14.当逻辑发生分支时,在顺序图中用          生命线发生的分支                      表示,在协作图中用          嵌套的序号                      表示。

15顺序图强调的是交互的         时间顺序    ,协作图强调的是交互的   空间关系     和参与交互的对象的        上下文环境      

 

16GRAPPLE

把开发过程分为5       ,之中又由许多      动作      组成。

17GRAPPLE

过程中,得到初步类图是在   需求收集       段,细化类图是在     需求分析       段。

18.每一个设计模式都集中于一个特定的                 设计问                    ,描述了    相互通信的对象或者类                                                                      以及      解决方案                 解决效果           

19面向对象系统中功能复用的两种最常用技术是        象组合               类继承     

20.设计模式中应优先使用      对象组合            而不是     类继承         

 

 

简答题

1.  类图在UML中有何重要作用?

答: 1.为开发人员提供这种模仿现实世界的表达方式。

2.让分析员使用客户所采用的术语和客户交流,促使客户说出所要解决的问题的重要细节。

 

2.阐述用例对于系统开发人员来说的价值。

答:

是用来从用户的观察角度收集系统需求的一项技术,便于分析员与客户和用户交流,使系统更符合用户的需求

 

3.简述如何在实际工作中发现类。

答:在与客户的交谈中,要注意客户用来描述业务实体的名词术语。这些名词可作为领域模型中的类。

还要注意你听到的动词,因为这些动词可能会构成这些类中的操作。

当得到一组类的核心列表后,应当向客户询问在业务过程中每个类的作用。他们的回答将告诉你这些类的职责。

 

 

4.简述怎样发现类之间的继承关系。

答:

作为候选的类有可能和它的父类、子类在谈话中同时被发现。系统分析员意识到某个类的属性和操作也许能被运用到其他多个类当中去。

另一种可能的情况是系统分析员注意到两个或者多个类可能具有相同的属性和操作数

 

 

5.试使用UML的关系表示法,表示出大学计算机专业中如下这些课程的模型:C语言程序设计、C++语言程序设计、Windows程序设计、网络程序设计。注意抽象类和依赖的使用。

 

 

6.画出图形用户界面GUI的状态图,要包括屏幕保护状态。其中要表明相应的事件、动作。

答:图形用户界面(GUI)是一个可以说明状态转移细节的例子。在这里,假设GUI可以处于以下3种状态之一:

        Initializing(初始化)

        Working(工作)

        Shut Down(关闭)

        当打开PC电源的时候,自启动发生。因此Turning the PC on(打开PC)是一个触发器事件,它导致了GUI的状态转移到Initializing状态,而Bootup(自启动)是一个在转移过程中执行的动作。

由于Initializing状态中活动的完成,GUI将转移进入Working状态。当你对PC选择ShutDown(关闭机器)时,就引发了Shut Down触发器事件,最后PC自己切断电源,整个过程结束。下面的状态图捕获了GUI的这些状态和转移。

下图是GUI加入

Screensaving状态和保护条件的状态图,注意图中的保护条件[is Timeout],被写成一个布尔表达式。

7.顺序图和协作图中,消息有哪三种?各自的意义和表示法什么?

答: 消息可以是简单的(simple)、同步的(synchronous)或异步的(asynchronous)。简单消息是从个对象到另一个对象的控制流的转移。如果一个对象发送了个同步消息,那么它要等待对方对消息的应答,收到应答后才能继续自己的操作。而发送异步消息的对象不需要等待对方的应答便可以继续自己的操作。在顺序图中,简单消息是个简单箭头,同步消息是实心箭头。异步消息是个半边箭头,

8.画出自动饮料销售机中,理想场景和“钱数不正确”的场景合并在一起的顺序图

假设在饮料销售机中有3个对象来做上述工作:前端(Front)(它是饮料销售机与顾客之间的接口),钱币记录仪(Register)(它负责收集顾客投的钱币),以及分配器(Dispenser)。我们还假设钱币记录仪控制分配器对象。那么对象之间的交互序列可能如下所示:

        1.顾客向机器前端的槽缝中投入钱币。

        2.顾客选择所要购买的饮料品种。

        3.钱币被转送给记录仪。

        4.由于这是一个理想情况下的场景,假设有饮料存货,则记录仪控制分配器将一罐饮料投递到销售机的前端。

由于上述对应的序列图只覆盖了用例“Buy soda”的一个场景(也就是一个实例),因此它被称之为实例顺序图(instance sequence diagram)。下图显示了对应的实例顺序图。注意图中只有简单消息,每个消息都引起控制流程从一个对象转移到另一个对象。

 

对于钱数不正确场景:

        1.记录仪检查顾客输入的钱币数星是否与所要购买的饮料价格匹配。

        2.如果输入数量大于价格,则记录仪计算两者之间的差额并检查机器中存有的金额。

        3.如果机器中刚好有能找给顾客的零钱,则记录仪将零钱找给顾客,一切按正常情况继续进行。

        4.如果没有零钱找给顾客,则记录仪退回顾客投入的钱币,并显示一个消息,提示顾客重新输入数量正确的金额。

5.如果顾客所输入的金额少于所要购买的饮料价格,则记录仪什么也不做,机器等待顾客继续投入钱币。

答:    为了表示顺序图中的每个“if”分支,可以将“if”选择条件写在方括号中,放到对应的消息箭头上,即增加[input=price][change in reserve][change not in reserve]3个选择条件。

        每个条件都引起消息中的控制流的一个分支,将消息分为多条路径。不同的消息路径最终可以到达同个对象。为了表达这种关系,接收对象的生命线

可分为多余路径。在消息序列的某一点上,信息的分支可以合并,生命线的路径也是如此。下图是加入了场景钱数不正确后的图。

 

9.画出自动饮料销售机中,理想场景和“钱数不正确”的场景合并在一起的协作图。

下面先来看看用例“Buy Soda(买饮料)”的最理想场景下的交互序列:

    1.顾客向机器前端的槽缝中投入钱币。

    2.顾客做出一个选择,选择所要购买的饮料品种。

    3.钱币被转送给记录仪。

    4.由于这是个理想情况下的场景,所以记录仪控制分配器将一罐饮料投递到销售机的前端。

这个场景的协作图如下图所示。

 

下面再看钱数不正确场景的协作图。这个协作图中要出现以下几个条件:

        1.用户输入的钱数超过了所要购买的饮料价格。

        2.饮料销售机中备有可找给顾客的零钱。

        3.饮料销售机中没有可找给顾客的零钱。

        在协作图中条件的表示方法与在顺序图中一样,都是用方括号将条件表达式括起来,放在消息名的前面。但是要注意的是消息的条件和序号之间的匹配关系。

        条件和序号可能会使图变得复杂,因此让我们一步一步地来建立这个场景的协作图,这个图的前提条件是用户输入的钱比所要购买的饮料价格高,并且机器中备有找给顾客的零钱。首先增加机器给顾客找零的消息,并为该消息附加上条件。给顾客找零消息是检查是否有找给顾客的零钱这一消息的直接后续消息。为了表明两条消息之间的这种关系,这两个消息采用同一序号,用序号后面的点再接序号来区分它们。这叫做消息嵌套(nesting)。下图说明了这个顺序图的细节。

如果机器中没有零钱可找会怎么样呢?销售机必须显示一条无零钱信息提示给顾客,并将顾客投入的钱币退出,提示顾客投入零钱。实际上,这时交易就结束了。

        要增加这个条件,就要增加控制流的分支。可以用嵌套序号表示这个控制流的序号。因为它是第2个被嵌套的消息,因此圆点后面的序号是2。最后,由于交易已经结束,该消息上要附加构造型《transaction over》来表明交易结束。此外还有另个发送饮料的消息。下图是这个场景的顺序图。

 

10.简述接口对于构件的重要意义。

答:

只能通过构件的接口来使用构件中定义的操作。

构件可以让它的接口被其他构件使用,以使其他构件可以使用这个构件中定义的操作。提供服务的构件提供了导出接口,访问服务的构件使用了导入接口。

 

11.简述当代面向对象软件工程的特点和优点。

允许各个阶段进行迭代

各个阶段没有明显的分界线

允许后期得到的信息返回,使得早期的能够被修改

重用性高、维护性好、扩展性高

 

12GRAPPLE

过程中,需求收集段的各个动作是什么?分别有什么工作产品?

答:

1  发现业务过程

工作产品是一个或者一组能够捕获业务过程中的步骤和判定点的活动图。

2  领域分析

工作产品是一个高层的类图和会谈记录。

3  识别协作系统

工作产品是新建的系统的部署图

4  发现系统需求

会议得到的工作产品是一个包图。

5  将结果提交给客户

这个动作的工作产品视不同的组织而不同。

13.简述类继承和接口继承的区别?我们应该尽量使用哪一种?

答:

类继承根据一个对象的实现定义了另一个对象的实现。简而言之,它是代码和表示的共享机制。然而,接口继承描述了一个对象什么时候能被用来替代另一个对象。

类继承是派生中的类将继承父类的所有属性和方法,并且可以在派生类里添加自己的属性和方法,而接口继承则是在接口里只定义接口的方法,没有属性,并且方法不能实现,只有在派生他的类才实现该方法。类继承是编译的时候新建对象,而接口实例是在运行时刻创建对象。我们应该尽量使用接口继承,类继承会产生类爆炸现象

 

14.只根据抽象类中定义的接口来操纵对象有什么好处?

1) 客户无须知道他们使用对象的特定类型,只须对象有客户所期望的接口。

 2) 客户无须知道他们使用的对象是用什么类来实现的,他们只须知道定义接口的抽象类。

 

15.可复用的面向对象设计的两条原则是什么?

1. 针对接口编程,而不是针对实现编程。不要将变量声明为一个特定类的实例对象,而是让他遵从抽象类所定义的接口

2.优先使用对象组合,而不是类继承。

 

16.设计模式的两大主题是什么?

对象组合

类继承的讨论

17.面向对象系统中功能复用的两种最常用技术是什么?

面向对象系统中功能复用的两种最常用技术是类继承和对象组合(object composition)

 

18Lexi系统的格式化问题中,我们引入了CompositorComposition两个类来实现“策略”模式。请画出这两个类各自的继承关系和它们之间的协作关系。

CompositorComposition

Compositor类。它的接口(见下表)可让Compositor获知何时去格式化哪些图元。它所格式化的图元是一个被称为Composition的特定图元的各个子图元。一个Composition在创建时得到一个Compositor子类实例,并在必要的时候(如用户改变文档的时候)让Compositor对它的图元作Compose操作。

下图描述了Composition类和Compositor类之间的关系。

19Lexi系统的支持多种窗口平台的问题中,我们使用了WindowWindowsImp类来实现桥接模式。请画出这两个类各自的继承关系和它们之间的协作关系。

 

原文地址:https://www.cnblogs.com/chentao/p/612526.html