|
& h! W' j: i0 a, i. ]$ Y
《面向对象的程序设计》期末考试A卷 8 }+ a! M C9 K# e: `7 W. I
" E+ n) U7 S' `5 T( m+ x. C% @
姓名:
/ l; r4 G$ R. f 专业:
; \+ L# B, l. @$ }; B 学号:
S8 G9 O. U/ I" c9 ^9 V 学习中心:" B$ U& j3 p- A; ?5 O. v) P8 x+ |
?$ w, x6 s! A+ @; F7 }' M: V, `% o
一、单选题 (请将资料填在下表中,共25题,每题2分,共50分)0 }2 y6 D+ m' M8 S2 R- {
1( q* b$ m* N8 J5 \4 F
2& t* l3 |' P5 b
38 E9 V7 i- z! o- y
4. q4 H) f7 p7 Z
5/ e9 U9 s8 y7 Z/ h
69 l2 w9 W2 |2 k8 _ @$ O3 s
7; s; K" T* p4 z3 l% h3 o5 G) y( L
8
# X E+ p( H5 O9( g9 T9 Z, i4 T- ?- k% a
108 R. ^* O( i8 h/ z; ~; ~+ q' F
9 Y: j' A% u- ?1 b$ ]; W8 j4 \8 F" x) v. |' f( _" Q
; C: [! ?' E6 X, Q0 k: |5 B
7 Y$ u0 K! Y8 A9 i7 J- q6 ]1 v; @* W" @; [: b$ w* k8 R6 [% l, i: {
- t X) H. N- p1 I- L; A+ w) a" \3 Q5 o
: ~) j8 ~7 L$ b6 I5 ^6 T
" S; w* x# R, j9 Z* s
T1 g- N, ~' h3 L: A$ e11( j# m; Q& u. y3 @2 Q
2
1 \' x) e4 f& ?13. n' D( c" u, _3 n3 |/ O
14
* {5 f* j. E4 u159 d! r- M% |. |1 R+ n) M6 @/ ~
16
* j2 r- ?! U6 M8 j7 [; V17/ |5 d! }4 L& J9 C" O8 q. u
186 D) w3 [/ T0 m1 L8 Y5 d
19: g- t9 i- P7 S/ u* s' p
20# ~' r6 ?/ p% J( K4 R* I
2 ?' T. k( z7 U% W3 l' Z
, ]! O7 S. L1 u
. T" _+ K* w( Q% }' E/ h& z- w5 ^5 M( k5 s( Q
3 o2 ? v; [( V% v6 s: y! Q. ~0 ?$ u4 R' f* c$ g
: V3 R8 o+ L; @* s% k. N* ?* _4 c
5 } k4 U2 B$ d6 r$ j0 m+ h
0 I6 P7 [$ k+ ~+ N- H1 V% Q
8 B4 @# m. [$ g, |8 S5 R' Q
21% O( d2 q) ]: Y4 |; V: V! V
22
- q9 ^* L d+ t23
3 I1 \0 n6 P) [; L# Z F, K2 _3 m24
& H1 m, e2 ~: _: K6 I. n25, Y- n$ @6 ]' [$ \
9 W+ a2 I d- A: Z' s6 R+ ^
( Y+ w# J& }; I1 p& ]! g& v! L% d
6 S! q! v; [) Z7 C8 h L
* G" e" N, x: r. r6 w) Z9 q- w# |1、Observer模式不适用于()。% {5 C; J% c1 N2 o, d5 f
A.当一个抽象模型存在两个方面,其中一个方面依赖于另一方面,将这二者封装在独立的对象中以使它们可以各自独立的改变和复用8 G7 B( c; y* a
B.当对一个对象的改变需要同时改变其他对象,而不知道具体有多少个对象有待改变时; {5 `% Q" I% h
C.当一个对象必须通知其它对象,而它又不能假定其它对象是谁,也就是说你不希望这些对象是紧耦合的' s, S: c4 `: H: v# o- q) i# x
D.一个对象结构包含很多类对象,它们有不同的接口,而想对这些对象实施一些依赖于其具体类的操作
W/ ~% S. {8 e, @" u
5 Q2 V5 Z. x9 v- R* Z Q2、顺序图由类角色,生命线,激活期和()组成。7 k/ {* d, G% t, v% C5 N( |$ i
A.关系
6 [/ ^$ b2 {2 c5 D# j* D6 DB.消息
3 @4 {4 |& c2 O4 L( I1 t) dC.用例8 W$ m# Z/ ?2 ~4 E+ J E, r; q
D.实体
7 u4 S4 S' d0 ?5 F* e6 ^( S5 c' V2 p
7 n" V! `: S& X9 _9 J! G3、UML中类的有三种,下面哪个不是其中之一()
) L9 u1 d& c" B# f) W2 r' @A.实体类4 ~( }0 i o7 w2 Z2 E' c
B.抽象类, @7 ^ M: ]1 D; u) i2 C
C.控制类
1 r8 Z9 |% f4 CD.边界类
. T7 w. V. ?) d& Q( s
: o$ y8 ]% |& a5 W0 `4、如果用例A与用例B相似,但A的功能较B多,A的动作序列是通过在B的动作序列中的某些执行点上插入附加的动作序列而构成的,则称()。
9 Q; }' u3 a9 P1 h) D- WA.用例A实现用例B
6 y3 t0 `; _1 j' z# dB.用例A继承用例B
2 F5 w5 Z1 \, U# c+ }# M, g2 o- k* ^C.用例A扩展用例B6 f3 v3 N6 C' ?1 k5 l
D.用例A包括用例B
: n* L7 @9 r1 F) @& V5 {: g' d
2 K4 G% I' [( { c5、( )技术是将一个活动图中的活动状态进行分组,每一组表示一个特定的类、人或部门,他们负责完成组内的活动。
# `$ c& f* T t5 HA.泳道+ x/ _2 u$ |: C& `1 w4 e X T3 t p
B.分叉汇合+ |! N" Q6 x3 K3 Z- A5 ^9 X
C.分支
3 m: Z2 o# v) R8 d/ gD.转移
3 B! ~* E6 Y2 S1 D$ Q2 j8 F. H& b: d2 C# A# S3 v6 p0 X& n
6、关于继承表述错误的是:()。) a" c) {9 I2 q6 A
A.继承是一种通过扩展一个已有对象的实现,从而获得新功能的复用方法' x0 k& {/ i# Y
B.泛化类(超类)可以显式地捕获那些公共的属性和方法。特殊类(子类)则通过附加属性和方法来进行实现的扩展/ y+ Z7 n- Y' K6 {1 Z/ u7 S. z" q
C.在一定意义上说破坏了封装性,因为这会将父类的实现细节暴露给子类
7 Q) E$ ?) U: f9 l8 z3 X2 ~D.继承本质上是“白盒复用”,对父类的修改,不会影响到子类7 w, L7 f4 J1 C: ~
1 w: x& H$ i. t) ]0 d
7、当我们想创建一个具体的对象而又不希望指定具体的类时,可以使用()模式。
: }' n4 R2 {- W( H8 [2 l) f" M* j- n8 dA.创建型
, ^! Q, s' W7 j- RB.结构型$ q4 `2 c/ ]. l
C.行为型7 S$ [. ]! A8 T8 e+ a
D.以上都可以 X$ k3 p4 M, ?
( i: [* _& {2 g. |8、类和接口的关系类似于下面哪种类型的关系()。( V% Q5 j" y7 g2 M9 G
A.关联(association)和聚集(aggregation)
* X. t4 L- p$ a* hB.关联(association)和组合(composition)4 v7 |: M8 b r0 v4 b
C.脚本(scenario)和用例(use case)! R+ q6 P7 u3 r2 ?' w
D.包(Package)和子系统(subsystem)
, u- [6 Q' R$ B; S2 ~/ j$ s; H2 @+ d. q/ X/ u* ~
9、如果用例B是用例A的某项子功能,并且建模者确切地知道在A所对应的动作序列中何时将调用B,则称()。1 F% ]$ I1 }& t( E9 h
A.用例A扩展用例B9 z; X4 l/ Y: O* u0 a
B.用例A继承用例B
$ n- w Z% K# _- r2 nC.用例A包括用例B
8 c" c/ N; M. F- |0 j; f( A* zD.用例A实现用例B( \7 p( G: z+ _6 @7 x( T* @
7 S1 D7 W2 C2 B3 B/ y0 x10、组成UML有三种基本的建筑块是:( ),事物和图。% `7 H: w( _0 `& B& B. E
A.关系# ^7 f4 b# P! x. I& D$ z2 v
B.类2 W; j4 H6 Y% O" o
C.用例
3 R# m( R, P5 k& Y. CD.实体
5 }% [. o5 x% l4 ?& A
9 L: K/ ` n0 C! {# t) J11、设计模式一般用来解决什么样的问题()。
d; ^" d. W& i. K7 E1 sA.同一问题的不同表相5 u- O* f# ~) h0 I0 e
B.不同问题的同一表相
; X+ \/ o8 U" A7 |' W4 f' L) bC.不同问题的不同表相 u3 ^8 ~/ | S, I' t5 ~. i# h
D.以上都不是
, C/ I' v9 ~1 B7 r% d7 s) U
: @% e. ~( j/ b2 ]; f2 _! r! i12、若将活动状态比作方法,那么动作状态即()。
3 W4 B( }4 m& RA.方法名3 A* B1 W' Q5 s3 A" y" _
B.方法返回值
1 ] y" _0 {3 y$ b/ `C.方法体中的每一条语句
8 ?- q' p! W( G& p% ~" VD.方法的可见性
7 r, L9 T3 {* A' T8 [" ?4 R e/ a
13、()是表达系统类及其相互联系的图示,它是面向对象设计的核心,建立状态图、协作图和其他图的基础。
! G" s. ~5 k/ N5 `A.对象图
, u; q1 ~& F- @. [, r: {B.组件图6 S+ {- o6 u- \" u' o+ ~, f
C.类图
8 _! Z" p+ g! n" t. p) | |- YD.状态图, H; K1 j' E0 T
4 V3 Q8 G6 y" e5 Q+ H14、()使用类图的一个子集,用于强化某个时间点类实例之间的关系。
! Z# P" h& X0 JA.交互图& D; J$ r) J7 O9 B
B.协作图
' N! B* h! T" n; rC.对象图) z0 l* h% k6 u8 O' k; ~
D.状态图
" H5 \; g& P' m# E7 [
# w( `2 r4 e. T! o/ ~! J15、40、在UML中()表示参与者为达成一项相对独立、完整的业务目标而要求软件系统完成的功能。
, T: K t# ?) uA.用例图4 X% d+ f {* T/ U- t' M
B.边/ F% h7 U) [" n% I9 O
C.执行者
5 `1 D: C7 p( B0 V" j6 }! _D.用例% y( W) o9 @- j6 n2 D+ @6 M
0 B. t9 s7 q- M16、通常对象有很多属性,下面仅能在对象内部访问的属性可见性限制是()。
7 k, q4 Z6 G. j5 O3 [' CA.公有的(public)
. W* _4 L9 I6 o3 CB.受保护的(protected)% p6 H2 o$ K9 E3 a
C.友员(friendly)+ \' u; d) r; \6 B; U3 ^0 d f
D.私有的(private); W: [( v& N% a! I
& [+ Z. `( s! G6 O% ~" @17、生命线是UML视图中哪个图形的组成部分()。
' u" B! L! _& }- } V! BA.类图 v+ s4 e; |$ p' E0 q
B.状态图0 q4 W" X8 [2 d7 M; z
C.活动图
3 _1 r4 Y, e) k* w1 j# Z9 _2 K& ID.顺序图0 Q+ l( }* K# j) W" Y. l7 U/ V# s
( E* {- B" ~0 f4 P" @" x18、下面()不是UML的基本构成元素。()) ]9 W; S9 x% P5 Z+ s
A.控制语言2 f' O& q& V. q6 G6 N. i/ K
B.基本构造块, u% u; T: q$ R% e0 k- h
C.规则. J' w3 H9 W7 k7 D( m( ^9 m
D.公共机制
w( i3 A k- F* {; R, v' f! w% k
5 g' N9 R9 J- O: Z- K' ]; r6 y; P19、在用例之间,会有三种不同的关系,下列哪个不是它们之间可能的关系( )$ v0 f- j- v# D* T6 ?! u7 G( a4 q; @- A
A.包含(include)" c k% a5 l0 e0 v2 u7 g
B.扩展(extend)
4 o8 @/ x! t5 ZC.泛化(generalization)
: d8 c8 S; S5 u: O7 u6 {D.关联(connect)
) T- J8 y/ Z6 C8 A: G- C( ^ [# O; h7 ?
20、面向对象程序设计将描述事物的数据与 () 封装在一起,作为一个相互依存、不可分割的整体来处理。
2 e8 v5 R* {+ V( P3 S! Y- O: J) }A.信息6 G' M$ P/ P4 u& Q( H/ b) z
B.数据隐藏9 ?& @: f0 Y( m3 j: p% b8 J/ p; j
C.对数据的操) ^3 s. M1 B3 z. h+ _5 Q
D.数据抽象8 `$ l* P$ ^( N. N: h
! s; E9 E3 f7 @- a" u% [
21、下面哪个视图属于UML语言的交互图()。) }- I# q% O) Q( T9 Z8 h8 J1 S- g
A.行为图 H: [' J' O2 m
B.状态图/ Z( j, b$ a1 R# @/ r0 ^ C% z8 i
C.实现图: @" N; h$ z- x( l. r5 |
D.顺序图) t; N* k! x# Y
6 x- m( y& f- W# Z5 H
22、()模型的缺点是缺乏灵活性,特别是无法解决软件需求不明确或不准确的问题。1 ~8 ?5 `4 Z. _# u' v8 i9 w# |/ @# h
A.瀑布模型# \! {" k8 h9 f! A
B.原型模型% u; D R/ T6 [1 e0 }* W
C.增量模型
) L. T) H1 C1 p/ VD.螺旋模型
! q, c+ M* @$ `6 r' w0 Y* x+ E2 [. T. B& C: N9 {
23、在UML中,有3种基本构造块,分别是()5 B6 Y8 F& L$ u2 ]! M, q2 @; D
A.事物、关系和图
F" H( G$ B" [/ a4 K3 s) E# |$ f! Z7 TB.注释、关系和图
6 w) G# n( k+ Y. m4 @% QC.事物、关系和结构) v9 a' b! v2 a0 a
D.注释、关系和结构
4 U& Z+ d* y/ T* L+ I4 [+ ~
, z$ U" y* Z8 F24、以下属于创建型模式的是()。4 v1 l2 T& r" U
A.抽象工厂模式(Abstract Factory)+ ^/ {7 L0 p4 M& I% d7 J. k
B.装饰模式(Decorator)& `, j* `. J* ~9 A6 I4 A7 m4 a
C.外观模式(Facade)9 P# x I) X7 X7 W, T+ q; B5 @9 }
D.桥接模式(Bridge)& v! D. z! }# Q7 P" w; X2 n
: T5 t8 X B3 |" G* ?( [& F8 O
25、Fa?ade(外观)模式的意图是()。" o! K4 V: A2 B6 f4 |+ q% Z
A.希望简化现有系统的使用方法。你需要定义自己的借口! @: `7 a% `" W# O
B.将一个无法控制的现有对象与一个特定借口相匹配' t& M8 Q# c' D4 B2 o+ X/ `
C.将一组实现部分从另一组使用它们的对象中分离出来+ n4 o8 o* w# J" W% p$ t
D.你需要为特定的客户(或情况)提供特定系列的对象
& ~9 @- I% B' d& w: D- [$ o, Z2 ^- B7 V. e; {* m
9 K2 s, o7 g% F3 ^ }
二、资料来源:谋学网(www.mouxue.com) (请将资料填在下表中,共10题,每题2分,共20分)0 W- b$ b, m$ A' {5 }5 K# e
26
`* }" h; o" w; T! p) } L275 F% e, V' ]3 q: n& X9 j7 K
28
' u" O4 K: c4 ~4 Y" U; e6 t( U1 m297 @; q7 M; v$ K8 x
309 u4 Z" g7 p" W% `* \4 S! C5 r
31( G+ }: q6 |6 V8 e3 t
32
* c1 V* M( }: p* I1 [0 r1 C33- O& v/ g7 d5 `$ J* b
34. y2 ?; N- A( G; A& I6 {
35/ \" U5 J2 R# d/ k2 D
% i9 b" }- t6 f( P* l+ s) V8 K
0 f/ l5 w1 S; D* U. v% q; J x# f( w0 N
% m& y% c, q q# v3 F8 R4 q/ F
& l* _2 R, U7 \# u: A7 g. U
6 o9 u4 B* @! r
2 f* t: X/ X5 k* k6 z" ~% ~% r% b* ~
6 D$ p( j5 @9 r* q0 \
1 T% B+ B4 J% m- K- n
26、抽象工厂模式提供了一系列相关或相互依赖对象的接口且必须指定他们具体的类。 ( )
2 ^2 i4 j! C+ ~: o5 f. W3 N1 y27、Decorator(装饰)模式适用性是表示对象的部分-整体层次结构。 ( )
% l# h/ c( _ R$ k3 A, E28、一个状态图最多只能由一个初态和一个终态。 ( ) _3 H0 Y" ]! h1 u. |3 ~/ b$ D
29、类A和类B之间的关系如图1所示,则称类B中的getName()方法是对类A中的getName()方法的重载(overload)。
6 Y7 ~4 ` q Q3 L3 O( ^; t' X% j: ?' z5 }; ?0 w
图 getName()方法之间的关系 ( ), X9 P2 z) E( j- t& n4 Y, f
30、Adapter模式不是必须针对某个接口进行设计。 ( )! @# \. b% I) }6 I& D/ R* _& P
31、对象适配器模式是合成聚合复用原则的典型应用。 ( )7 K. _* X7 B' Z' @2 E; }+ M9 C7 y
32、Decorator(装饰)模式的意图是为一个对象连接附加的职责。 ( )
4 S& I& i9 {: [4 H% A33、在设计模式中,“效果”只是指“原因和结果”。 ( )
! x' h6 A/ j* q6 r8 N; }3 ?. A% [* ?34、Fa?ade外观模式只能为方法调用创建更简单的接口,不能减少客户必须处理的对象数量。 ( )4 i2 L2 F y3 n9 f, b
35、UML由用例视图、物理视图、组件视图、进度视图和配置视图组成。 ( )
7 K" `' A/ p+ ]0 B6 q
) k5 e. w7 i) [& ?三、更多资料下载:谋学网(www.mouxue.com) (共4题,每题5分,共20分)
! O: F* Y* B% N3 T% U; j36、信用卡可能处于“开放”和“关闭”状态,其中“开放”状态可以直接进入“关闭”状态,而从“关闭”状态必须提供密码验证才能进入“开放”状态。“开放”状态又包括“透支”和“正常”状态之间的变化,当剩余金额少于零、或者使用额度大于剩余金额、或者结算余额小于零时进入透支状态,反之则为正常状态。画出信用卡的状态图。' m: u5 S# p) i# L, Q* N
' h* O( I6 x( r! H `# Z1 G _9 L; o q- y0 C5 r
37、UML2.0前有几种常用图(diagram)?哪些属于静态图,哪些属于动态图?
; t6 H6 c9 D+ r4 q3 H- q, d( z- ]9 q& i* P5 E2 a- D1 W
5 U# r9 S8 Z, `6 y38、UML中的交互图有两种,分别是顺序图和协作图,请分析一下两者之间的主要差别和各自的优缺点。掌握利用两种图进行的设计的方法。
4 W2 ^% ?; \) u: `$ K- h+ V4 N6 j$ e) F9 M
7 p! c) l! a2 B: P! z39、说明Observer模式的基本实现方式。如果不用该模式,要达到同样的效果,你会如何做? v/ B# i1 ]' p+ j% e# \9 c* L. I
* i- n; b4 b7 m+ |/ s6 O w+ Z" Q
* @- C# J! h) ~1 H: l* H
7 Q) Y6 h- X0 R2 g( d5 q
四、设计题 (共1题,每题10分,共10分)
3 h. r4 l. S& `" p9 b40、根据下面的叙述,绘制一幅关于顾客从自动售货机中购买物品的顺序图。7 ]# Y# H! k7 |# p& y# e
顾客(User)先向自动售货机的前端(Front)投币;/ g L' }* T9 d
售货机的识别器(Register)识别钱币;" }3 K$ P1 ~7 t) l
售货机前端(Front)根据Register的识别结果产生商品列表;5 b$ f3 |9 h) `1 e" Z
顾客选择商品;
/ O6 v# S& { f9 T ^3 p识别器控制的出货器(Dispenser)将所选商品送至前端(Front)。
" o* V5 n: F' z; q- g) d0 G" F
0 |7 [( m! o( D. y' q
& }0 U5 ]) u e. H6 K# G- O/ s- s
1 |' A0 b6 t+ }& L) t. w1 z▆/ I8 e7 u+ e8 b
; q6 z( l m3 O
8 q0 }, ]) b/ \8 P
* M! D: {" S9 {" c) V6 Z) g▆ ■ ■ ■ ■ ■ ■ ■ ■ ■ ■ ■ ■
6 @- N) `; ]3 w: f
" M* e1 E: g; M# q: u( }
; A" R9 \3 E9 P- F* P# N: _4 T▆ 《面向对象的程序设计》 试卷 共3页(第 2 页) 资料务必写在对应的作答区域内,否则不得分,超出黑色边框区域的资料无效! ▆
! O2 R8 f b8 \. f4 c1 |( U5 J2 J1 E) v# t$ B- x
▆ 《面向对象的程序设计》 试卷 共3页(第 1 页) 资料务必写在对应的作答区域内,否则不得分,超出黑色边框区域的资料无效! ▆
+ P- u& \, r" m+ p: A5 A" s2 F# T
" o) O) t& R* {1 ^6 l7 F |
|