|
东 北 大 学 继 续 教 育 学 院
; g# H* [8 T( s- n( W 软件设计模式(一)X 试 卷(作业考核 线上2) B 卷(共 7 页)
: f9 Q. m+ F# h. S; {# ^% ^总分 题号 一 二 三 四 五 六 七 八 九 十: i# [# F2 v) `, g( V+ w
得分
$ ~1 U6 ^6 f8 V" k一、单选题(共40分,每题2分)
! |* ?9 Z/ [; O: }8 q. ^1. 常用的基本设计模式可分为()
, I) L# }! \ B7 }7 p' ^A.创建型、结构型和行为型 B. 对象型、结构型和行为型
+ U9 P* j c" o8 E$ e! [C.过程型、结构型和行为型 D. 抽象型、接口型和实现型- V6 \" M3 K9 q8 }* n/ B7 w: h
2. 对以下开闭原则的描述错误的是()$ H5 f( k# G6 G3 J: I+ \
A.开闭原则与“对可变性的封装原则”没有相似性
: }9 `; h1 v$ D/ A, FB.找到个系统的可变元素,将它封装起来,叫开闭原则
, c5 A2 d* Z6 F, F' {# }C.对修改关闭,是其原则之一
4 i4 x/ r% V1 p/ w/ E6 h, }' B3 KD.从抽象层导出一个或多个新具体类可以改变系统的行为,是其原则之一% w0 i# |+ g! ]0 T
3. “不要和陌生人说话”是()原则的通俗表述。
- M- ^0 |) ?& b/ t ~A. 接口隔离 B. 里氏替换 C. 依赖倒置 D. 迪米特
1 z0 @3 Z0 b6 B4. 当创建一个具体的对象而又不希望指定具体的类时,可以使用()
# U& _4 {0 F+ E" q- HA. 结构型 B. 创建型 C. 行为型 D.以上都可以
% N1 P# ?% Q- g. C0 [( D0 G5. 以下( )是利用一个对象,快速地生成一批对象。
7 X5 `5 d' L! e% KA. 抽象工厂(Abstract Factory)模式 B. 原型(Prototype)模式
S: H& |6 ]- k% b- n6 SC. 合成(Composite)模式 D. 桥接(Bridge)模式0 i1 q1 S. p {4 D
6. 以下( )用来描述建造者( Builder )。
/ A/ q" }9 A1 Q6 }: }8 OA. 定义一个用于创建对象的接口,让子类决定实例化哪一个类
4 n) [1 H- W! Z) J2 ]5 f% YB. 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示
* R; R# K7 e! d. NC. 保证一个类仅有一个实例,并提供→个访问它的全周访问点 J U' H8 f4 G2 I' U D
D. 运用共享技术有效地支持大量细粒度的对象
& h, [2 R# u% }2 F7. 以下( )用来描述工厂方法(Factory Method)模式。
. S, e. |- c+ N! B- xA. 提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类- f( K' [- P, m2 J/ F
B. 表示一个作用于某对象结构中的各元素的操作。它使用户可以在不改变各元素的类的前提下定义作用于这些元素的新操作
; U! w! [7 z; @/ o- QC. 定义一个用于创建对象的接口,让子类决定实例化哪一个类。该模式使一个类的实例化延迟到其子类
9 ^- d' U7 Q! ?! V4 S- wD. 定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化
, D* c ^6 F9 k7 P N0 K. w# M+ d8. 对象适配器模式是( )原则的典型应用。
$ L; |- W4 F- W( Z' S) AA. 将一个类的接口转换成客户希望的另外一个接口,本模式使原本由于接口不兼容而不能一起工作的那些类可以一起工作。
+ G) q }: l8 \3 {B. 定义一个用于创建对象的接口,让子类决定实例化哪一个类* `( H J ~) [/ s4 Q; w5 y: z
C. 表示一个作用于某对象结构中的各元素的操作,它使用户可以在不改变各元素的类的前提下定义作用于这些元素的新操作
; v1 W4 y+ e) t8 S: e! AD. 将一个请求封装为一个对象,从而使用户可用不同的请求对客户进行参数化; 对请求排队或记录请求日志,以及支持可撤销的操作( f P# z5 B: P
9. 关于模式适用性,以下( )不适合使用Flyweight(享元)模式。
. W5 @4 R# U, I2 ]A. 一个应用程序使用了大量的对象
, Y8 e( Y4 w# z+ p. w8 }B. 完全由于使用大量的对象, 造成很大的存储开销
- _" F9 t# S0 V W; B& @C. 对象的大多数状态都可变为外部状态
1 F/ A/ R; d! l: z3 J0 TD. 用户想使用一个已经存在的类,而它的接口不符合用户的需求
* K6 C+ C. W( M; K/ c10. 下面不属于创建型模式的有( )。) I' O4 [- R0 j9 T( o5 U- d
A. 抽象工厂模式(Abstract Factory) B. 适配器模式 (Adapter) k# x9 c" x+ N! F) d/ C1 |
C. 工厂方法模式(Factory Method) D.单例模式(Singleton)
; G3 l- |/ f6 U: a0 C11. 定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。这句话是对哪种模式的描述( )。3 t5 }( c& K. G7 }
A.观察者模式(Observer) B.桥接模式(Bridge)+ M# O" E1 b2 z7 J* H- S5 U o
C.适配器模式(Adapter) D.策略模式(Strategy)- v" H/ C ?) K7 I* D
12. 若系统中的某子模块需要为其他模块( )提供访问不同数据库系统的功能,这些数据 库系统提供的访问接口有一定的差异,但访问过程却都是相同的,例如,先连接数据库,在打开数据库,最后对数据库进行查询,设计模式可抽象出相同的数据库访问过程。- \8 ]+ |1 M. D }0 Z1 R R
A. 外观 B. 装饰 C.单间 D.模板方法* F/ L+ W9 N3 ?# c* I
13. Decorator(装饰)模式的意图是:( )。
. \; b4 s. K+ ~# MA. 定义一系列的算法,把它们一个个的封装起来,并且使它们可相互替换。
/ [9 [% h" y @2 z! i( g( QB. 为一个对象动态连接附加的职责。
f9 q v- i8 I- X4 u, aC. 你希望只拥有一个对象,但不用全局对象来控制对象的实例化。
2 O; _- \* W) Q% \D. 在对象之间定义一种一对多的依赖关系,这样当一个对象的状态改变时,所有依赖于它的对象都将得到通知并自动更新。
/ ~8 K% w, Q# `0 s! i2 a8 v14. Singleton模式适用于( )。
( z/ E) O" S6 H0 N G1 Q sA. 当类有多个实例而且客户可以从一个众所周知访问点访问它时。
" P- O. ~6 _9 U9 nB. 当这个唯一实例应该是通过子类化可扩展的,并且客户应该无需更改代码就能使用一个扩展的实例时。
4 ~2 n2 g) I' y9 c: R2 RC. 当构造过程必须允许被构造的对象有不同的表示时。$ V2 g# e/ e! h* K* B
D. 生成一批对象时。
* n% J. d% [! Y- L; x* X- E: F; _( ^15. 下列模式中,属于行为模式的是( )。
' q4 }7 h; S0 I4 o! IA. 工厂模式 B. 适配器 C. 观察者 D.以上都是+ ]. ~. A/ J- d" y3 s, x
16. 关于工厂方法,以下叙述不正确的是( )。
, ?: v4 |7 ^3 NA. Factory Method是一个用于帮助分配创建的责任的模式。
) `0 u% l* i4 Y/ kB. Factory Method模式和Abstract Factory模式总是配合使用。4 @+ t' |8 r" L" y
C. Factory Method适用于将对象实例化的规则推迟到某个派生类的情形。& I. s) n/ F" B. M' n2 A& l0 @/ I
D. Factory Method是属于创建型模式。9 l/ u. u+ F# ~- @" D! J6 o
17. 以下意图( )可用来描述解释器(Interpreter)。
* Q2 B# R: W' V) k5 DA. 将抽象部分与它的实现部分分离,使它们都可以独立变化
; |; O6 U$ ]/ I3 Z9 a: ^3 ^1 l, OB. 给定一个语言, 定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子: J5 Q: L4 W+ y4 C
C. 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示( l8 d3 g7 f1 y% Y/ g" n; K" W
D. 为其他对象提供一种代理以控制对这个对象的访问& k. D M5 q& R
18. 在观察者模式中,表述错误的是( )。
& Q- o' F; ?2 q) @$ |6 r. HA. 人观察者角色的更新是被动的
7 T& [) O" e1 H4 k) |/ ]- zB. 被观察者可以通知观察者进行更新; K% n. Q$ B4 [9 p
C. 观察者可以改变被观察者的状态,再由被观察者通知所有观祟者依据被观察者的状态挂行D. 以上表述全部错误
) `, @6 z1 n/ w9 j/ H5 z2 E- d3 X19. 以下意图( )是用来描述组合(Composite)。
, F7 G7 d8 t- J' BA. 为其他对象提供一种代理以控制对这个对象的访问0 V% C7 @. n- S: ^0 |' x1 d
B. 运用共享技术有效地支持大量细粒度的对象4 w. v) @5 v/ ?
C. 将对象组合成树形结构以表示“部分”整体”的层次结构
; G* y( t K0 KD. 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示( g) j, ?$ t- j
20. 设计模式具有的优点()。
) i. p1 e3 w& C% x" TA. 适应需求变化 B. 程序易于理解 7 [" K" k" j5 w! a& k) O+ A; V
C.减少开发过程中的代码开发工作量 D. 简化软件系统的设计8 @; E7 U" P) Q# q' I. D
二、多选题(共10分,每题2分)9 _2 h, m1 c' Q7 C
1. 以下是模式的基本要素的是( )。* ~! x/ T. B5 W7 V/ L2 U8 I0 g
A. 名称 B. 意图 C. 解决方案 D. 参与者和协作者
# L+ [ w! k$ Z' Q" e c S2. 当应用工厂方法( Factory Method )模式时要考虑( )。
# h& T6 @% o" z7 O1 `7 ^5 {3 GA. 主要有两种不同的情况 B. 参数化工厂方法
2 ` a; ~1 c$ G5 R* ?C. 特定语言的变化和问题 D. 使用模板以避免创建子类. L. r& T0 t" f& }$ F
3. 以下属于结构型模式的是( )。
5 j U, \. v) V) J6 V. v' x5 tA. 代理(Proxy) 模式 B. 合成(Composite)模式( {! W: p& O, ?" {5 I5 r# \
C. 命令(Command)模式 D.观察者(Observer)模式! S; [7 y8 X3 m! V, W
4. 装饰( Decorator )模式的两个主要缺点是( )。
: {, b! Y6 G- r, d; i) v. dA. 比静态继承更灵活 B.避免在层次结构高层的类有太多的特征
7 ^% w: P3 P$ k1 @3 hC. 有许多小对象,很容易对它们进行定制,但是很难学习这些系统,排错也很困难( E+ |6 s, a+ l, E4 v
D. 装饰与它的组成不一样,装饰是一个透明的包装
, l7 M2 F( v& B$ [" y* e% X5. 中介者模式有以下( )优点。$ X" J, v! R! m% C8 J5 U$ I2 M
A. 简化了对象之间的交互 B. 简化了同事类的设计和实现4 M: F) b, w9 r. Q! m
C. 封装了转换规则 D. 减少了子类生成; |$ Z. D2 r4 Q( G Z- d: w
三、资料来源:谋学网(www.mouxue.com)(共10分,每题1分;请在认为正确的题目后面写T,错误的题目后面写F)0 ^9 z U6 ? Q) K3 e; b
1. 设计模式的两大主题是系统复用与系统扩展。( )
! R# _1 i5 { m2 e2. 抽象工厂模式提供了一系列相关或相互依赖对象的接口且必须指定他们具体的类。( )
) N/ c) `: L3 x- \3. 对象适配器模式是依赖倒转原则的典型应用。( )
6 p- v1 I6 N# V: C: Z3 N+ }1 {7 l4. Open-Close原则的含义是一个软件实体应当对扩展开放,对修改关闭。( )+ h. j$ X+ m( R5 |1 V" [8 h
5. Singleton(单例)模式属于结构性模式。( )
( m9 ]' i! a( y( \6. 常用的设计模式可分为过程型、创建型和结构型。( )0 N0 r( e1 H% P% E4 ?& T4 Y
7. 对观察者模式,触发事件的对象——Subject对象不需要知道观察事件的所有对象。( )1 Q' B+ f/ r# T" v
8. 通过在问题领域中使用模式,可以用一种不同的方式来看待问题。( )1 h& O4 S1 C! n0 R% v
9. Strategy模式可以用不同的方式调用所有的算法。( )
/ [, a- \5 K+ @/ q+ ^9 m* B10. 当依赖关系固定(或几乎固定)时,加入一个Observer(观察者)模式可能只会增加复杂性。( )0 w3 k7 w3 D7 G9 M2 K) C1 x
四、更多资料下载:谋学网(www.mouxue.com)(共15分,每题3分)
: z- S1 b0 e k' j. i1. 设计模式
) h7 U4 A( ^9 y" @' |) \4 l) K( ~. I; c' _% p2 V
4 }0 `" [* t5 k0 @8 [( J' b- i8 Y) p& A" O
2. 开闭原则
( h8 p& h3 c0 y6 D V0 H+ R. n, c
& _) c v0 |8 C9 z# I
! ]0 Z; Z$ H# w* G. T. g
3.单一职责原则3 Q" W3 U+ x, o/ ^- l2 n+ X3 o
! a3 K% P# g( G/ E9 |
. d$ X& }/ ]7 b
8 C! Y! R* x) a7 h4.依赖关系) v+ o4 o8 V9 G8 t4 L/ W! C
. _1 R' ~, K C" F+ k! a
( V Z3 p" g; h" ~. m
1 P% g& t5 T1 A9 D" Z6 { s r5.组合关系- ]4 A; r! W$ m. c+ {( d; e+ B* g
" g3 J/ N& ^% s" k1 m8 k
) d4 }8 O( [4 ^% M9 o
l& J: O+ [2 X$ @五、更多资料下载:谋学网(www.mouxue.com)(共15分,每题5分)
' b: r+ g) l& y1. 设计模式一般有哪几个基本要素?. v! G8 b1 Z' E
: G9 N6 B! l" ^7 T+ P
2 [* y( N: m' }, m, G
5 o/ u. m: V/ O+ B( |& T
! @9 p6 V+ U" J0 |
' M3 A2 q! H9 `; s9 q7 z t+ y- p# f5 d1 l6 E t- V b3 c% h9 O
. Z5 Y, l! h3 S. i( p. D2 `! k' ^' i
2. 创建型模式分包括哪几种设计模式,各是什么并简要说明。
. k7 l' ` w S' B7 Q, M; r$ }! g& X5 U+ A$ M
: \' [/ Z4 N" e, W; X9 i! }! f. l/ K. U! f: k p; X1 u/ @
. `2 s% p* ]& v# x- a
, M" a" B- Q) K! B v
* q: n% K5 F% P i' L' c+ J
) |5 Y- l/ |. \3 B; t1 n3. 说明访问者模式的定义与主要优缺点。
l# f* w2 T# z0 L+ H/ q" P8 C
$ ^( j8 r O& O3 G5 G
# N/ M8 Z5 c$ B, l7 _+ B# i
& n# _* G$ V- C. I5 {* o
& a" _% e7 q! P0 l+ c8 D6 n5 G# a
; [1 m3 p' o( q; `) @
& b: _/ y" L3 h" i
* F# f5 J# r' z0 e
& O/ ^* P8 d6 f4 _% D
! M B1 c& s/ l8 s# a( V% k
W% S6 }( ^! Q: z& c! N- ~
六、综合题(共10分)$ w0 k. j( |7 l% ^8 _/ `: _
当“人民币汇率” 升值时, 进口公司的进口产品成本降低且利润率提升,出口公司的出口产品收入降低且利润率降低; 当“人民币汇率” 贬值时,进口公司的进口产品成本提升且利润率降低, 出口公司的出口产品收入提升且利润率提升。利用观察者模式设计一个程序, 分析“人民币汇率”的升值或贬值对进口公司的进口产品成本或出口公司的出口产品收入以及公司的利润率的影响。
- G n L, z4 X- @9 @6 w提示:这里的汇率(Rate) 类是抽象目标类,它包含了保存观察者(Company ) 的List 和增加/删除观察者的方法, 以及有关汇率改变的抽象方法change(int number); 而人民币汇率(RMBrate)类是具体目标,它实现了父类的change(int number)方法,即当人民币汇率发生改变时通过相关公司; 公司(Company)类是抽象观察者, 它定义了一个有关汇率反应的抽象方法respons巳(int number); 进口公司( ImportCompany )类和出口公司( E xportCompany )类是具体观察者类,它们实现了父类的response(int
* h* P' [6 }* J. E, n& ynumber)方法, 即当它们接收到汇率发生改变的通知时作为相应的反应。
4 |3 o6 S1 `0 i0 | W请画出该程序的类图。
' v) x7 l' p- N5 x# i3 _) }. f. ?+ x9 W; C8 M. k9 t2 M% g. z
4 x8 X, B' S8 A1 V9 \) F
% a) x/ I+ Z& O9 N) Y! ^# V* A
- ^& ^# ~6 R/ \2 v/ f- h: K& T) T$ h( w
& | L) p& M' g! u
m& U4 |8 C( @; s e3 f& l; A: n/ e8 Q) W
% j: A0 Z1 Q+ j; A
+ `, p* Z5 j0 E0 J$ n9 A1 e: E0 n3 v0 F7 v# O
, A6 o7 c) U% o8 F" [
: `. I/ W$ D) `6 `( A# s3 M
9 v5 O2 @4 Q" v
+ ]& S1 E" ~8 K! Q- D8 }* [9 T3 q" _% L1 d
; b* y4 A- R8 E; W: y
/ e7 Z/ j9 P5 ~' H( ~5 O
/ r. I+ _$ u4 }2 U3 _# C! V( J C- ~8 A) Y4 {' P9 g! J! }4 i
|
|