软件需求工程(精品).ppt
《软件需求工程(精品).ppt》由会员分享,可在线阅读,更多相关《软件需求工程(精品).ppt(44页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、软件需求工程软件需求工程2 2第二第二 章章第二章第二章 软件需求工程软件需求工程2 22.1 2.1 软件需求分析的基本概念软件需求分析的基本概念2.2 2.2 结构化分析方法结构化分析方法2.32.3 原型化方法原型化方法(维护报告)开发时期运行时期计划时期(目标与范围说明书)(可行性论证论告)(测试报告)(程序)(设计文档)(需求说明书)瀑布模型瀑布模型瀑布模型瀑布模型软件需求分析是软件生命期中重要的一步,也是决定性的一步。软件需求分析是软件生命期中重要的一步,也是决定性的一步。2.1 2.1 2.1 软件需求分析的基本概念软件需求分析的基本概念软件需求分析的基本概念 对对系系统统应应该
2、该提提供供的的服服务务和和所所受受到到的的约约束束进进行行理理解解、分分析、建立文档、检验的过程析、建立文档、检验的过程需求工程需求工程1.1.什么是软件需求工程?什么是软件需求工程?2.2.软件需求分析的任务是什么?软件需求分析的任务是什么?3.3.需求工程过程需求工程过程4.4.软件需求分析方法软件需求分析方法2.1 软件需求分析的基本概念 2.1.1 软件需求分析的任务需求分析阶段的任务:需求分析阶段的任务:在在可可行行性性分分析析的的基基础础上上,进进一一步步了了解解确确定定用用户户需需求求。准准确确地地回回答答 “系统必须做什么?系统必须做什么?”的问题。获得需求规格说明书。的问题。
3、获得需求规格说明书。Boehm对软件需求的定义:对软件需求的定义:研研究究一一种种无无二二义义性性的的表表达达工工具具,它它能能为为用用户户和和软软件件人人员员双双方方都都接接受受并能够把并能够把“需求需求”严格地、形式地表达出来。严格地、形式地表达出来。由于需求分析方法不同,描述形式不同。其实现步骤如下图所示:由于需求分析方法不同,描述形式不同。其实现步骤如下图所示:当前系统当前系统模型化模型化目标系统目标系统物理模型物理模型具体化具体化物理模型物理模型抽象化抽象化逻辑模型逻辑模型实例化实例化逻辑模型逻辑模型做做什么什么导导出出理理解解需需求求 表表达达需需求求2.1.1 软件需求分析的任务
4、软软 件需件需 求求用用 户需户需 求求系系 统需统需 求求功能功能需求需求非功能非功能需求需求领域领域需求需求2.1.2 2.1.2 需求工程过程需求工程过程 问题识别问题识别分析与综合分析与综合编写文档编写文档分析评审分析评审2.1.2 需求分析过程可行性研究可行性研究需求导出需求导出和分析和分析需求描述需求描述需求有效性需求有效性验证验证可行性报告可行性报告系统模型系统模型用户需求和用户需求和系统需求系统需求需求文挡需求文挡近近几几年年来来已已提提出出许许多多软软件件需需求求分分析析与与说说明明的的方方法法,每每一一种种分分析析方法都有独特的观点和表示方法,但都适用下面的基本原则。方法都
5、有独特的观点和表示方法,但都适用下面的基本原则。2.1.3 2.1.3 需求分析的原则需求分析的原则2.1.3 需求分析的原则1 1、能够表达和理解问题的信息域和功能域、能够表达和理解问题的信息域和功能域对对于于计计算算机机程程序序处处理理的的数数据据,其其信信息息域域包包括括信信息息流流(如如下下图图,即即数数据据通通过过一一个个系系统统时时的的变变化化方方式式)、信信息息内内容容和和信信息息结结构构,而而功功能能域反映上述三方面的控制信息。域反映上述三方面的控制信息。数据存储数据存储转换转换1 1转换转换2 2附加附加数据数据输入数据输入数据中间数据中间数据结果数据结果数据2.1.3 需求
6、分析的原则2 2、能够对问题进行分解和不断细化,建立问题的层次结构。、能够对问题进行分解和不断细化,建立问题的层次结构。3 3、需要给出系统的逻辑视图和物理视图、需要给出系统的逻辑视图和物理视图软软件件需需求求的的逻逻辑辑视视图图给给出出的的是是软软件件要要达达到到的的功功能能和和要要处处理理信息之间的关系,而不是实现的细节。信息之间的关系,而不是实现的细节。软软件件需需求求的的物物理理视视图图给给出出的的是是处处理理功功能能和和信信息息结结构构的的实实际际表现形式,这往往是由设备本身决定的。表现形式,这往往是由设备本身决定的。2.1.4 2.1.4 需求分析方法需求分析方法不同的开发方法,需
7、求分析的方法也有所不同,常见的分析方法有:不同的开发方法,需求分析的方法也有所不同,常见的分析方法有:2.1.4 需求分析方法功能分析方法功能分析方法 将将系系统统看看作作若若干干功功能能模模块块的的集集合合,每每个个功功能能又又可可以以分分解解为为若若干干子子功功能能,子功能还可继续分解子功能还可继续分解,分解的结果已经是系统的雏形。分解的结果已经是系统的雏形。面向对象的分析方法面向对象的分析方法 面面向向对对象象的的分分析析方方法法(OOA)的的关关键键是是识识别别问问题题域域内内的的对对象象,分分析析它它们之间的关系,并建立起三类模型。们之间的关系,并建立起三类模型。信息建模法信息建模法
8、 是从数据的角度对现实世界建立模型的是从数据的角度对现实世界建立模型的,基本工具是基本工具是ERER图。图。结构化分析方法结构化分析方法 是是一一种种以以数数据据、数数据据的的封封闭闭性性为为基基础础,从从问问题题空空间间到到某某种种表表示示的的映映射方法,由数据流图(射方法,由数据流图(DFD图)表示。图)表示。结构化开发方法结构化开发方法结构化开发方法结构化开发方法(Structured Developing MethodStructured Developing Method)是是现现有有的的软软件件开开发发方方法法中中最最成成熟熟,应应用用最最广广泛泛的的方方法法,主主要特点是快速,自
9、然和方便。要特点是快速,自然和方便。结结构构化化方方法法总总的的指指导导思思想想自自顶顶向向下下、逐逐步步求求精精。它它的的基基本本原则是功能的分解与抽象。原则是功能的分解与抽象。2.2 2.2 结构化分析方法结构化分析方法结构化开发方法的组成结构化开发方法的组成 7070年代初年代初 结构化程序设计方法结构化程序设计方法 SP法(法(Structured Program)7070年代中年代中 结构化设计方法结构化设计方法 SD法(法(Structured Design)7070年代末年代末 结构化分析方法结构化分析方法 SA法(法(Structured Analysis)SA,SD,SP 法
10、法相相互互衔衔接接,形形成成了了一一整整套套开开发发方方法法。若若将将SA,SD 法法结结合合起起来来,又又称称为为结结构构化化分分析析与与设设计计技技术术(SADT 技术)。技术)。2.2.1 SA2.2.1 SA法概述法概述分分解解:对对于于一一个个复复杂杂的的系系统统,为为了了将将复复杂杂性性降降低低到到可可以以掌掌握握的的程程度度,可可以以把把大大问问题题分分解解成成若若干干小小问问题题,然然后后分分别别解解决决(如如右右图图)。一、一、一、一、SASA法的基本思想法的基本思想法的基本思想法的基本思想 结构化分析方法的基本思想是结构化分析方法的基本思想是“分解分解”和和“抽象抽象”。抽
11、抽象象:分分解解可可以以分分层层进进行行,即即先先考考虑虑问问题题最最本本质质的的属属性性,暂暂把把细细节节略略去去,以以后后再再逐逐层层添添加加细细节节,直直至至涉涉及及到到最最详详细细的的内内容容,这这种种用用最最本本质质的的属属性性表表示示一一个个系系统统的的方方法法就就是是“抽抽象象”。2.2.1 SA法的概述1.11.21.3x2132.12.22.31.11.31 1、建立当前系统的、建立当前系统的“具体模型具体模型”。基本思想与步骤基本思想与步骤三、三、三、三、SASASASA法的描述方法法的描述方法法的描述方法法的描述方法1 1、分层的数据流图、分层的数据流图2 2、数据词典、
12、数据词典3 3、描述加工逻辑的结构化语言、判定表及判定树、描述加工逻辑的结构化语言、判定表及判定树2.2.1 SA法的概念二、二、二、二、SASASASA法的步骤法的步骤法的步骤法的步骤4 4、为为了了对对目目标标系系统统做做完完整整的的描描述述,还还需需要要考考虑虑人人机机界界面面和和其他一些问题。其他一些问题。3 3、建立目标系统的逻辑模型。、建立目标系统的逻辑模型。2 2、抽象出当前系统的逻辑模型。、抽象出当前系统的逻辑模型。顾客出版社验证验证订单订单汇总汇总订单订单订单出版社 订单图书目录文件图书目录文件顾客档案顾客档案待处理订单文件待处理订单文件正确订单一批订单出版社档案文件出版社档
13、案文件订货存根文件订货存根文件DFD图的图的例子例子加工名加工名编号编号加工名加工名编号编号文件名文件名文件名文件名顾顾客客出出版版社社验证验证订单订单汇总汇总订单订单订单订单出版社出版社 订单订单图书目录文件图书目录文件顾客档案顾客档案待处理订单文件待处理订单文件正确正确订单订单一批一批订单订单出版社档案文件出版社档案文件订货存根文件订货存根文件画图步骤画图步骤 :1 1、确定外部实体及输入、输出数据流。、确定外部实体及输入、输出数据流。2 2、确定分解顶层的加工。、确定分解顶层的加工。3 3、确定使用的文件。、确定使用的文件。4 4、用数据流将各部分连接起来,形成数据封闭。、用数据流将各部
14、分连接起来,形成数据封闭。注意:标注各加工框及数据流名称。注意:标注各加工框及数据流名称。例例1 1:图书预定系统:图书预定系统(顶层(顶层DFDDFD图)图)P26 图图2.7 2.2.2 2.2.2 数据流图数据流图数数据据流流图图(Data Data Flow Flow DiagramDiagram,DFDDFD)是是描描述述系系统统中中数数据据流流程程的的图图形形工工具具,它它标标识识了了一一个个系系统统的的逻逻辑辑输输入入和和逻逻辑辑输输出出,以以及及把把逻逻辑输入转换为逻辑输出所需的加工处理。辑输入转换为逻辑输出所需的加工处理。数据存储数据存储数据源点数据源点或终点或终点加加 工工
15、加工名数据流数据流数据流名文件名实体名箭箭 头头圆或椭圆圆或椭圆单或单或双杠双杠矩形框矩形框还有一些辅助的图例还有一些辅助的图例:2.2.2 分层的数据流图一、数据流图的图符一、数据流图的图符四种基本图形符号:四种基本图形符号:TAB*CTAB*CTAB+CTAB+CTABC+TABC+*与与+或或互斥+“先全局后局部先全局后局部,先整体后细节先整体后细节,先抽象后具体先抽象后具体”通常可将这种分层的通常可将这种分层的DFDDFD图图,分为顶层、中间层、底层。分为顶层、中间层、底层。具体步骤:具体步骤:1 1。先确定系统范围,画出顶层的。先确定系统范围,画出顶层的DFDDFD图。图。2 2。逐
16、层分解顶层。逐层分解顶层DFDDFD图,获得若干中间层图,获得若干中间层DFDDFD图。图。3 3。画出底层的。画出底层的DFDDFD图。图。2.2.3 2.2.3 画分层画分层DFDDFD图的方法图的方法 顶顶层层图图说说明明了了系系统统的的边边界界,即即系系统统的的输输入入和和输输出出数数据据流流,顶顶层层图图只只有有一一张张。底底层层图图由由一一些些不不能能再再分分解解的的加加工工组组成成,这这些些加加工工都都已已足足够够简简单单,称称为为基基本本加加工工。在在顶顶层层和和底底层层之之间间的的是是中中间间层层。中中间间层层的的数数据据流流图图描描述述了了某某个个加工的分解,而它的组成部分
17、又要进一步分解。加工的分解,而它的组成部分又要进一步分解。画各层画各层DFDDFD图时,图时,“由外向内由外向内”。X1321.11.21.41.32.12.21.1.11.1.22.1.32.1.22.1.12.2.22.2.32.2.1顶顶层层中中 间间 层层底底 层层先全局后局部先全局后局部,先整体后细节先整体后细节,先抽象后具体先抽象后具体.0图1图2图1.1图2.1图2.2图分层DFD 图经过初步的需求分析,得到系统功能要求:经过初步的需求分析,得到系统功能要求:1 1、监视病员的病症(血压、体温、脉搏等)。、监视病员的病症(血压、体温、脉搏等)。2 2、定时更新病历。、定时更新病历
18、。3 3、病员出现异常情况时报警。、病员出现异常情况时报警。4 4、随机地产生某一病员的病情报告。、随机地产生某一病员的病情报告。2.2.4 实例:医院病房监护系统产生产生病情报告病情报告监视病情监视病情更新病历更新病历2.2.4 实例:医院病房监护系统系统功能要求:系统功能要求:1 1、监视病员的病症(血压、体温、脉搏等)、监视病员的病症(血压、体温、脉搏等)2 2、定时更新病历、定时更新病历 3 3、病员出现异常情况时报警。、病员出现异常情况时报警。4 4、随机地产生某一病员的病情报告。、随机地产生某一病员的病情报告。顶层:顶层:病员病员护士护士护士护士病员监病员监护系统护系统病员病员日志
19、日志病症信号病症信号要求报告要求报告病症病症报告报告报警报警例例2 2 医院病房监护系统医院病房监护系统第一层:第一层:病员病员护士护士护士护士中央监视中央监视病员病员日志日志病症信号病症信号要求报告要求报告病症病症报告报告报警报警局部监视局部监视生成报告生成报告病员极限病员极限更新日志更新日志病员数据病员数据格式化格式化病员数据病员数据生理信号生理信号极限值极限值1324日志数据日志数据日志数据日志数据医院病房监护系统顶层医院病房监护系统顶层DFDDFD图图第二层:加工第二层:加工“中央监视中央监视”分解分解计算超过计算超过极限值否极限值否病员数据据超过极限值报警开解信号开解信号产生产生报警
20、信息报警信息病员极限病员极限格式化格式化病员数据病员数据体温血压、体温脉搏生理信号极限值时间脉搏血压日期时钟时钟格式化病员数据3.13.23.23.33.33.43.4医院病房监护系统二层医院病房监护系统二层DFDDFD图图计算超过计算超过极限值否极限值否病员数据超过极限值报警开解信号开解信号产生产生报警信息报警信息病员极限病员极限格式化格式化病员数据病员数据体温血压、体温、脉搏生理信号极限值时间脉搏血压日期时钟时钟格式化病员数据3.13.23.23.33.33.43.4第二层:加工第二层:加工“中央监视中央监视”分解分解医院病房监护系统分层医院病房监护系统分层医院病房监护系统分层医院病房监护
21、系统分层DFDDFDDFDDFD图图图图图 2.15第一层第一层格式化格式化病员数据病员数据生理信号生理信号极限值极限值病员病员护士护士护士护士中央监视中央监视病员病员日志日志病症信号病症信号要求报告要求报告病症病症报告报告报警报警局部监视局部监视生成报告生成报告病员极限病员极限更新日志更新日志病员病员数据数据1324日志数据日志数据图 2.16加工分解的原则加工分解的原则自然性自然性:概念上合理、清晰;概念上合理、清晰;均均匀匀性性:理理想想的的分分解解是是将将一一个个问问题题分分解解成成大大小小均均匀匀的的几几个部分;个部分;分分解解度度:一一般般每每一一个个加加工工每每次次分分解解最最多
22、多不不要要超超过过个个子子加工加工,分解应分解到基本加工为止。分解应分解到基本加工为止。2.2.5 2.2.5 画分层画分层DFDDFD图的基本原则图的基本原则数据守恒与数据封闭原则数据守恒与数据封闭原则 所所谓谓数数据据守守恒恒是是指指加加工工的的输输入入输输出出数数据据流流是是否否匹匹配配,即即每每一一个个加加工工既既有有输输入入数数据据流流又又有有输输出出数数据据流流。或或者者说说一一个加工至少有一个输入数据流,一个输出数据流。个加工至少有一个输入数据流,一个输出数据流。数据封闭是对整个系统而言。数据封闭是对整个系统而言。合理使用文件合理使用文件 当当文文件件作作为为某某些些加加工工之之
23、间间的的交交界界面面时时,文文件件必必须须画画出出来来,一一旦旦文文件件作作为为数数据据流流图图中中的的一一个个独独立立成成份份画画出出来来了,那么他同其他成份之间的联系也应同时表达出来。了,那么他同其他成份之间的联系也应同时表达出来。DFDDFDDFDDFD图不是流程图图不是流程图图不是流程图图不是流程图,不表示软件的控制流程。不表示软件的控制流程。不表示软件的控制流程。不表示软件的控制流程。2.2.5 2.2.5 画分层画分层DFDDFD图的基本原则图的基本原则子图与父图的子图与父图的“平衡平衡”父图中某个加工的输入输出数据流应该同相应的子父图中某个加工的输入输出数据流应该同相应的子图的输
24、入输出相同图的输入输出相同(相对应),分层数据流图的这种特相对应),分层数据流图的这种特点称为子图与父图点称为子图与父图“平衡平衡”。2.2.6 分层DFD图的改进 DFD图必须经过图必须经过反复修改反复修改,才能获得最终的目标系统的,才能获得最终的目标系统的逻辑模型(目标系统的逻辑模型(目标系统的DFD图)。可从以下方面考虑图)。可从以下方面考虑DFD图图的改进:的改进:1 1、检查数据流的正确性、检查数据流的正确性 数据数据守恒守恒 子图、父图的平衡子图、父图的平衡 文件使用是否合理。特别注意输入文件使用是否合理。特别注意输入/出文件的数据流。出文件的数据流。2 2、改进、改进DFDDFD
25、图的易理解性图的易理解性 简化加工之间的联系(加工间的数据流越少,独立性越简化加工之间的联系(加工间的数据流越少,独立性越强,易理解性越好)。强,易理解性越好)。改进分解的均匀性。改进分解的均匀性。适当命名(各成分名称无二义性,准确、具体)。适当命名(各成分名称无二义性,准确、具体)。分分层层数数据据流流图图只只是是表表达达了了系系统统的的“分分解解”,为为了了完完整整地地描描述述这这个个系系统统,还还需需借借助助“数数据据词词典典”和和“小小说说明明”对图中的每个数据和加工给出解释。对图中的每个数据和加工给出解释。对对数数据据流流图图中中包包含含的的所所有有元元素素的的定定义义的的集集合合构
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件 需求 工程 精品
限制150内