软件工程课件之_需求分析(第五版)(张海潘编著)_第1页
软件工程课件之_需求分析(第五版)(张海潘编著)_第2页
软件工程课件之_需求分析(第五版)(张海潘编著)_第3页
软件工程课件之_需求分析(第五版)(张海潘编著)_第4页
软件工程课件之_需求分析(第五版)(张海潘编著)_第5页
已阅读5页,还剩67页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 3.1 需求分析的任务 3.2 与用户沟通获取需求的方法 3.3 分析建模与规格说明 3.4 实体-联系图 3.5 数据标准化 3.6 状态转换图 3.7 其他图形工具 3.8 验证软件需求第3章 需求分析第3章 需求分析需求分析的任务:需求分析是软件定义时期的最后一个阶段,它的根本任务是准确地答复“系统必须做什么?这个问题。确定系统必须完成哪些工作,也就是对目标系统提出完整、准确、清晰、具体的要求。系统分析员应该写出软件需求规格说明书,以书面形式准确地描述软件需求。 需求:正在构建的系统必须符合的事务。需求管理:是一种获取、组织并记录系统需求的系统化方案以及一个使客户与工程团队不断变更的系

2、统需求达成并保持一致的过程。传统需求分析:强调需求的记录,以一成不变的观点对待需求,不重视需求实现与维护。现代需求过程:包括需求的获取、分析、处理、验证、实现和全过程的需求管理。需求管理覆盖软件工程的整个过程。传统与现代需求方法的比较: 需求管理过程需求管理功能需求管理思想方法传统局限于需求分析这一个阶段注重具体的需求分析方法一成不变的观点,注重“描述”的方法和过程,是纯技术性的转换现代全过程的,注重整个产品过程的全部功能范围更广,包括获取、分析、处理、验证、实现和全过程的需求管理注重需求实现与维护过程,处理不断变更的系统需求需求管理存在的问题:范围问题:系统目标、边界未被良好定义,用户和开发

3、团队理解不一致。理解问题:用户不能完全了解自己需要什么,对系统能力、局限更加不清楚;工程师不理解用户的问题域和应用环境。易变问题:需求随时间发生变化。需求工程:20世纪80年代中期,形成了软件工程的子领域需求工程。进入20世纪90年代后,需求工程称为软件界研究的重点之一。Alan Davis 把需求工程定义为“直到但不包括把软件分解为实际架构构件之前的所有活动。需求工程的阶段划分:3.1 需求分析的任务 确定对系统的综合要求 分析系统的数据要求 导出系统的逻辑模型 修正系统开发方案 3.1.1 确定对系统的综合要求 1. 功能需求2. 性能需求3. 可靠性和可用性需求4. 出错处理需求5. 接

4、口需求6. 约束7. 逆向需求8. 将来可能提出的要求3.1.2 分析系统的数据要求建立数据模型ER图 描绘数据结构层次方框图和Warnier图 数据结构标准化 3.1.3 导出系统的逻辑模型 综合上述两项分析的结果可以导出系统的详细的逻辑模型,通常用数据流图、实体-联系图、状态转换图、数据字典和主要的处理算法描述这个逻辑模型。 根据在分析过程中获得的对系统的更深入更具体的了解,可以比较准确地估计系统的本钱和进度,修正以前制定的开发方案。 3.1.4 修正系统开发方案 3.2 与用户沟通获取需求的方法访谈 面向数据流自顶向下求精简易的应用规格说明技术 快速建立软件原型 需求分析综合症解决方案需

5、求诱导的方法:3.2.1 访谈1. 正式访谈系统分析员将提出一些事先准备好的具体问题。2. 非正式访谈分析员将提出一些用户可以自由答复的开放性问题,以鼓励被访问人员说出自己的想法。3. 调查表经过仔细考虑写出的书面答复可能比被访者对问题的口头答复更准确。4. 情景分析技术对用户将来使用目标系统解决某个具体问题的方法和结果进行分析。情景分析技术的用处:能在某种程度上演示目标系统的行为,从而便于用户理解,而且还可能进一步揭示出一些分析员目前还不知道的需求。能保证用户在需求分析过程中始终扮演一个积极主动的角色。让用户起积极主动的作用对需求分析工作获得成功是至关重要的。3.2.2 面向数据流自顶向下求

6、精 1. 分析追踪数据流图需求分析的目标之一就是把数据流和数据存储定义到元素级,通常从数据流图的输出端着手分析。2. 用户复查必须请用户对上述分析过程中得出的结果仔细地复查。复查过程验证了的元素,补充了未知的元素,填补了文档中的空白。随着分析过程的进展,经过问题和解答的反复循环,分析员越来越深入具体地定义了目标系统,最终得到对系统数据和功能要求的满意了解。 面向数据流自顶向下求精过程3.2.3 简易的应用规格说明技术简易的应用规格说明技术是一种面向团队的需求收集法。这种方法提倡用户与开发者密切合作,共同标识问题,提出解决方案要素,商讨不同方案并指定根本需求。 分析需求的典型过程如下:1. 初步

7、访谈,准备会议首先进行初步的访谈,初步确定待解决的问题的范围和解决方案。然后开发者和用户分别写出“产品需求。选定会议的时间和地点,并选举协调人。2. 会前审查需求,确定列表要求每位与会者在开会的前几天认真审查产品需求,并且列出对象、操作这些对象或与这些对象交互的效劳、约束条件和性能标准。3. 会上讨论列表,创立组合列表每位与会者展示列表供大家讨论。大家共同创立一张组合列表。由协调人主持讨论这些列表。4. 分组制定小型规格说明与会者分成更小的小组,为每张列表中的工程制定小型规格说明。每个小组都向全体与会者展示他们制定的小型规格说明,供大家讨论。5. 制定确认标准,起草需求规格说明书每个与会者都制

8、定出产品的一整套确认标准,并提交会议讨论,以创立出意见一致确实认标准。最后,起草完整的软件需求规格说明书。简易的应用规格说明技术的优点:开发者与用户不分彼此,齐心协力,密切合作;即时讨论并求精;有能导出规格说明的具体步骤。 3.2.4 快速建立软件原型 快速建立软件原型是最准确、最有效、最强大的需求分析技术。快速原型就是快速建立起来的旨在演示目标系统主要功能的可运行的程序。构建原型的要点是,它应该实现用户看得见的功能,省略目标系统的“隐含功能。快速原型的特性:“快速。快速原型的目的是尽快向用户提供一个可在计算机上运行的目标系统的模型。因此,原型的某些缺陷是可以忽略的。“容易修改。如果原型的第一

9、版不是用户所需要的,就必须根据用户的意见迅速地修改它,构建出原型的第二版,以更好地满足用户需求。如果修改耗时过多,势必延误软件开发时间。 快速原型通常使用下述3种方法和工具:(1) 第四代技术4GL第四代技术包括众多数据库查询如SQL和报表语言如ADF、程序和应用系统生成器如Power Builder和Oracle的应用开发环境以及其他非常高级的非过程语言。第四代技术使得软件工程师能够快速地生成可执行的代码,它们是较理想的快速原型工具。 第四代技术特点:简单易学,用户界面良好,面向问题、非过程化程度高,用户只需告知系统做什么,而无需说明怎么做。用4GL编程使用的代码量较少,并可成数量级地提高软

10、件生产率。程序设计语言划代:1GL是汇编语言;2GL是高级程序设计语言,如FORTRAN,ALGOL,BASIC,LISP等;3GL是增强性的高级程序设计语言,如PASCAL,ALGOL68,FORTRAN77等;4GL是按计算机科学理论指导设计出来的结构化语言,如ADA,MODULA2,SMALLTALK80,JAVA,VB,VC,VF等。 (2) 可重用的软件构件另外一种快速构建原型的方法,是使用一组已有的软件构件(也称为组件)来装配(而不是从头构造)原型。软件构件可以是数据结构(或数据库),或软件体系结构构件(即程序),或过程构件(即模块)。(3) 形式化规格说明和原型环境非形式化方法:

11、自然语言描述半形式化方法:数据流图或实体-联系图形式化方法:基于数学的技术 3.3 分析建模与规格说明3.3.1 分析建模模型:就是为了理解事物而对事物做出的一种抽象,是对事物的一种无歧义的书面描述。通常,模型由一组图形符号和组织这些符号的规那么组成。结构化分析过程:实质上是一种创立模型的活动。系统分析员从不同角度抽象出目标系统的特性,使用精确的表示方法构造系统的模型,验证模型是否满足用户对目标系统的需求,并在设计过程中逐渐把和实现有关的细节加进模型中,直至最终用程序实现模型。 分析模型的结构需求分析过程应该建立3种模型,分别是:数据模型功能模型行为模型 数据字典:是分析模型的核心,它描述软件

12、使用或产生的所有数据对象。实体-联系图:描绘数据对象及数据对象之间的关系,是用于建立数据模型的图形。数据流图:描绘当数据在软件系统中移动时被变换的逻辑过程,指明系统具有的变换数据的功能,因此,数据流图是建立功能模型的根底。状态转换图(简称为状态图):指明了作为外部事件结果的系统行为。为此,状态转换图描绘了系统的各种行为模式(称为“状态)和在不同状态间转换的方式。状态转换图是行为建模的根底。 3.3.2 软件需求规格说明 通过需求分析除了创立分析模型之外,还应该写出软件需求规格说明书,它是需求分析阶段得出的最主要的文档。通常用自然语言完整、准确、具体地描述系统的数据要求、功能需求、性能需求、可靠

13、性和可用性要求、出错处理需求、接口需求、约束、逆向需求以及将来可能提出的要求。 我国定义了GB856D-1988国家标准,给出了需求规格说明的内容框架:1 引言 1.1 编写目的 1.2 项目背景(单位和其他系统的关系) 1.3 定义(专门术语和缩写词)2 任务概述 2.1 目标 2.2 运行环境 2.3 条件限制3 数据描述 3.1 静态数据 3.2 动态数据 3.3 数据库描述 3.4 数据字典 3.5 数据采集4 功能需求 4.1 功能划分 4.2 功能描述5 性能需求 5.1 数据精确度 5.2 时间特性 5.3 适应性6 运行需求 6.1 用户界面 6.2 硬件接口 6.3 软件接口

14、 6.4 故障处理7 其他需求(检测或验收标准、可用性、可维护性、可移植性、安全保密性)练习题:习题3.3,画数据流图顶层数据流图功能级数据流图细化的数据流图3.4 实体-联系图概念性数据模型是一种面向问题的数据模型,是按照用户的观点对数据建立的模型。它描述了从用户角度看到的数据,它反映了用户的现实环境,且与在软件系统中的实现方法无关。数据模型中包含3种相互关联的信息:数据对象数据对象的属性数据对象彼此间相互连接的关系 3.4.1 数据对象 数据对象:是对软件必须理解的复合信息的抽象。复合信息是指具有一系列不同性质或属性的事物,仅有单个值的事物不是数据对象。数据对象可以是外部实体、事物、行为、

15、事件、角色、单位、地点或结构等。数据对象彼此间是有关联的。 3.4.2 属性属性:定义了数据对象的性质。必须把一个或多个属性定义为“标识符 。根据对问题的理解来确定特定数据对象的适宜的属性。 3.4.3 联系联系:数据对象彼此之间相互连接的方式称为联系,也称为关系。联系可分为以下3种类型:一对一联系(11)一对多联系(1N)多对多联系(MN)联系也可能有属性。3.4.4 实体-联系图的符号ER图中包含:实体(即数据对象),用矩形框表示;关系,用连接相关实体的菱形框表示;属性,用椭圆形或圆角矩形表示,并用直线把实体(或关系)与其属性连接起来。例1:某校教学管理系统的ER图ER图的优点:比较接近人

16、的习惯思维方式;用简单的图形符号表达系统分析员对问题域的理解,用户也容易理解,可以作为用户与分析员之间有效的交流工具。 数据建模工具:以自动化的方式创立ER图、数据字典及相关模型。AllFusion ERWin 辅助设计数据库、数据对象、结构、关键元素ER/Studio 支持实体-关系建模Oracle Designer 建模、应用系统和数据库设计Meta Scope 图形化显示数据Model Sphere Visible Analyst 模型可视化分析例2:习题3.3,银行储蓄系统的ER图 银行计算机储蓄系统的工作过程大致如下:储户填写的存款单或取款单由业务员键入系统,如果是存款那么系统记录存

17、款人姓名、住址(或 号码)、身份证号码、存款类型、存款日期、到期日期、利率及密码(可选)等信息,并印出存单给储户;如果是取款而且存款时留有密码,那么系统首先核对储户密码,假设密码正确或存款时未留密码,那么系统计算利息并印出利息清单给储户。银行储蓄系统的ER图 3.5 数据标准化数据结构标准化:软件系统经常使用各种长期保存的信息,这些信息通常以一定方式组织并存储在数据库或文件中,为减少数据冗余,防止出现插入异常或删除异常,简化修改数据的过程,通常需要把数据结构标准化。 范式:通常用“范式(normal forms)定义消除数据冗余的程度。第一范式(1 NF)数据冗余程度最大,第五范式(5 NF)

18、数据冗余程度最小。范式级别越高,存储同样数据需要分解成更多张表,因此,“存储自身过程越复杂。随着范式级别的提高,数据的存储结构与基于问题域的结构间的匹配程度也随之下降,因此,在需求变化时数据的稳定性较差。范式级别提高那么需要访问的表增多,因此性能(速度)将下降。第一、第二和第三范式的定义:第一范式,每个属性值都必须是原子值,即仅仅是一个简单值而不含内部结构。第二范式,满足第一范式条件,而且每个非关键字属性都由整个关键字决定(而不是由关键字的一局部来决定)。第三范式,符合第二范式的条件,每个非关键字属性都仅由关键字决定,而且一个非关键字属性不能仅仅是对另一个非关键字属性的进一步描述(即一个非关键

19、字属性值不依赖于另一个非关键字属性值)。 3.6 状态转换图状态转换图:通过描绘系统的状态及引起系统状态转换的事件,来表示系统的行为。状态图还指明了作为特定事件的结果系统将做哪些动作(例如,处理数据)。 3.6.1 状态 状态:是任何可以被观察到的系统行为模式,一个状态代表系统的一种行为模式。状态规定了系统对事件的响应方式。状态主要有:初态(即初始状态),只能有1个终态(即最终状态),可以有0至多个中间状态状态图分类:表示系统循环运行过程,通常不关心循环是怎样启动的。表示系统单程生命期,需要标明初始状态和最终状态。3.6.2 事件事件:是在某个特定时刻发生的事情,它是对引起系统做动作或(和)从

20、一个状态转换到另一个状态的外界事件的抽象。简而言之,事件就是引起系统做动作或(和)转换状态的控制信息。 3.6.3 符号初态:用实心圆表示;终态:用一对同心圆(内圆为实心圆)表示;中间状态:用圆角矩形表示,分成上、中、下3局部。上面局部-为状态的名称;中间局部-为状态变量的名字和值;下面局部-是活动表。 带箭头的连线:称为状态转换,箭头指明了转换方向。 状态图中使用的主要符号活动表的语法格式: 事件名(参数表)/动作表达式“事件名可以是任何事件的名称。常用的3种标准事件:entry事件指定进入该状态的动作;exit事件指定退出该状态的动作;do事件那么指定在该状态下的动作。需要时可以为事件指定

21、参数表。活动表中的动作表达式描述应做的具体动作。 事件表达式的语法: 事件说明守卫条件动作表达式事件说明的语法为:事件名(参数表)。守卫条件是一个布尔表达式。如果同时使用事件说明和守卫条件,那么当且仅当事件发生且布尔表达式为真时,状态转换才发生。如果只有守卫条件没有事件说明,那么只要守卫条件为真状态转换就发生。动作表达式是一个过程表达式,当状态转换开始时执行该表达式。 3.6.4 例子例1: 系统例2:银行储蓄系统存款过程的状态图例2:银行储蓄系统取款过程的状态图3.7 其他图形工具3.7.1 层次方框图层次方框图:用树形结构的一系列多层次的矩形框描绘数据的层次结构。树形结构的顶层是一个单独的

22、矩形框,它代表完整的数据结构;下面的各层矩形框代表这个数据的子集;最底层的各个框代表组成这个数据的实际数据元素(不能再分割的元素)。某计算机公司的全部产品的层次方框图3.7.2 Warnier图Warnier图:和层次方框图类似,Warnier图也用树形结构描绘信息,但是这种图形工具比层次方框图提供了更丰富的描绘手段。特点:用Warnier图可以说明信息的逻辑组织,也可以表示特定信息在某一类信息中是有条件地出现的。因为重复和条件约束是说明软件处理过程的根底,所以很容易把Warnier图转变成软件设计的工具。 软件产品的Warnier图3.7.3 IPO图IPO图:是输入、处理、输出图的简称,它

23、是美国IBM公司开展完善起来的一种图形工具,能够方便地描绘输入数据、对数据的处理和输出数据之间的关系。根本形式:是在左边的框中列出有关的输入数据,在中间的框内列出主要的处理,在右边的框内列出产生的输出数据。在IPO图中还用类似向量符号的粗大箭头清楚地指出数据通信的情况。主文件更新处理的IPO图改进的IPO图:这种图中包含某些附加的信息,在软件设计过程中将比原始的IPO图更有用。在需求分析阶段可以使用IPO图简略地描述系统的主要算法(即数据流图中各个处理的根本算法)。 IPO表系统:定货系统 作者:祁燕模块:处理事务 日期:2010.3编号:1.0被调用: 定货系统调用: 接受事务 更新库存清单 处理定货输入: 事务输出:定货信息 库存清单处理:(用

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论