第3章 需求分析及功能建模方法
' D/ K! f# K4 P# d3.1 需求分析概述
+ K$ c( k$ H, }3.1.1 需求分析概念4 y! y. ?% \9 y1 h
1、 所谓需求分折:就是对待开发的系统要做什么,完成什么功能的全面描述。
$ S0 m( w6 e- S+ Q8 ^2、 需求分析的工作:通过对需求的调查、了解、观察和分析,通过对原始数据的收集、分类和抽象,并采用有效的技术、工具,对原始资料进行加工整理,描述开发目标、实现的功能及其相互关系等活动的集合;* t9 ~/ g E" @: K' ?( `( ^
3、 需求的定义:客户对一个待开发的系统在实现目标、完成功能、应达到的性能、安全性、可靠性等方面的期望和要求的集合;; x! ^, f a ^6 Z- }
4、 需求获取的困难:4 _+ m8 K3 R$ h
(1) 软件功能复杂;* m3 \( F- J# d8 \0 D) y% H, s+ j
(2) 需求的可变性;6 N; b0 v) S9 ^3 ]1 h2 E, @
5、 需求分析阶段的主要任务:分析当前的业务流程,包括体系结构,各职能部门完成的主要任务、关系及其交流的信息。
/ u9 A }7 z' I* y6、 需求分析的结果通常以模型等建模工具和方法描述系统的信息流、功能结构及完成各功能需要的数据。% R+ [6 o8 m5 r: ]% n2 Q8 X* s
7、 功能模型和软件需求规格说明书是软件开发的依据,将指导后续的开发工作。4 \( i* Z+ \3 E( Z
8、 需求分析工作是系统分析员与用户不断交互的过程中完成的。
& D, h- q7 N9 O* l' m3.1.2 系统分析员的职能
3 F4 P' C5 f& u# p z1、 系统分析员的主要要任务:是确定应用信息系统及软件产品应该达到的各项功能性要求和非功能性要求,即用户要做什么。
. \: L& |4 J' s; s- _8 N6 K# z2、 系统分析员应该具备的素质:
( L& y3 s8 L; K(1) 获取需求的能力;: `1 c; t( T- T [* z& y
(2) 管理及沟通能力;, K2 Q+ a! m/ l. i2 d0 B8 J! z4 E
(3) 技术素养;4 t8 j* z/ L& Q1 @5 ?
3.1.3 需求获取的方法
- S( w# t6 i+ J3 m) i0 M* L常用的几种获取需求的方法:(1)面谈;(2)实地观察;(3)问卷调查;(4)查阅资源;: b" P: m3 ]/ H- x) T* k
3.1.4 需求分析过程
0 c( F1 i7 d( M8 {, p# U# J8 H4 |1、 标识问题:
. I1 \; v* C$ [8 c+ y: v* b(1) 需求分析的第一步,通过对问题的识别和标识获得所求解问题及其运行环境的理解;
: T. _3 L T3 A6 r1 c(2) 标识问题从现行系统的业务流程做起,理解现行系统的业务流程;
h, ~, d. f& f3 N) _(3) 在标识理解需求的同时,还要注意确定系统的人机界面;3 a9 d+ p4 K' @# o. F8 R
2、建立需求模型:$ h% C( {, B! n, j/ O+ ]8 Y5 t
(1) 模型是对现实原形所作的一种抽象,其本质是只关心与研究内容有关的因素,而忽略无关的因素,其目的是把复杂的事物变得简单,便于认识和分析;# D' o @3 [1 `( y$ |9 v! F- g
(2) 目前常用的模型方法主要有DFD数据流图和IDEFO,都属于结构化分析方法,其特征是抽象和分解;0 n$ a3 ]: F2 O Y0 i3 X
(3) 首先对应用领域进行全面的分析,发现并找出同类事物的本质,用抽象方法把这类事物的非主要方面剔除,把握住事物的内部规律或本质,就可以找到解决办法;然后采用自上而下逐步求精的方法对复杂的问题进行分解;1 n/ v5 u0 `7 Y# ]) [5 r
(4) 结构化分析及建模方法的主要优点:
, I( M- d9 N i% m1 P(A) 不过早陷入具体的细节;, k6 w/ Q! C g0 j! r* J
(B) 从整体或宏观入手分析问题;" z: E2 g4 }! B5 B2 L2 g
(C) 通过图形化的模型对象直观地表示系统要做什么,完成什么功能;5 C" ?' Y$ h9 W4 e1 p
(D) 图形化建模方法方便系统分析员理解和描述系统;
4 @! N! I4 y0 Y(E) 模型对象不涉及太多的技术术语,便于用户理解;
9 y1 y$ H! V' f4 t5 K3、描述需求:
: t& V0 ]9 ~! q2 J8 h(1) 需求描述的目标:对软件项目功能性和非功能性的需求全面描述;
4 q& F) S" i7 B4 q- b& I) f# S(2) 功能性需求:指需要计算机实际解决的问题或实现的具体功能,明确描述系统必须做什么,实现什么功能以及输入输出等;
S( Y- e1 K: S; M: g(3) 非功能性需求:软件项目对实际运行环境的要求;
$ w! i# {1 N6 b/ K$ j$ c$ v6 S$ p4 R(4) 需求描述主要由需求模型和需求说明书组成,说明书侧重文字说明,内容如下:需求概述;功能需求;信息需求;性能需求;环境需求;其他需求;
. N' v8 i# P: c1 c4 g4 y0 R. A(5) 在对需求进行分析过程中,系统分析员要经常考虑的问题:
( I/ U$ t2 q0 X# ~. l- Q(A) 描述的需求是完全的吗?
5 K( C' y7 D1 ~- f$ f9 h(B) 需求描述是正确的和一致的吗?) t: F! a: u6 u& h9 m
(C) 描述的这些需求是可行的、实际可操作的吗?6 a! v) Z0 f; [7 p
(D) 描述中的每一条需求都是客户需要的吗?
+ X9 Q6 k% C0 f' Y/ n$ A8 x' U4、确认需求: T+ i% a. ^% W) u6 \8 W, N
1、 评审委员会审核下列内容:功能需求;数据需求;性能;数据管理;其他需求。 |