版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
软件工程讲稿第1页,课件共115页,创作于2023年2月§1需求分析的任务
请思考涉及到的几个主要问题:如何定义系统需求?如何识别、获取需求?
你能够采取何种手段与用户进行交流或沟通?何为需求建模?
你如何理解模型与建模?第三章软件需求分析
准确地定义待开发系统的目标,确定为了满足用户的需求,系统必须做什么?用《需求规格说明书》规范的形式准确地表达用户的需求。用户分析员程序员需求分析是软件定义时期的最后一个阶段,其基本任务是准确地回答“系统必须做什么?”,而不是确定系统怎样去完成这些工作,也就是要对目标系统提出完整、准确、清晰、具体的要求。在需求分析阶段结束之前,系统分析员应该写出软件需求规格说明书,以书面形式准确地描述软件需求。在分析软件需求和书写软件需求规格说明书的过程中,分析员和用户都起着关键的、必不可少的作用。只有用户才真正知道自己需要什么,但是他们并不知道怎样用软件实现自己的需求,用户必须把他们对软件的需求尽量准确、具体地描述出来;分析员知道怎样用软件实现人们的需求,但是在需求分析开始时他们对用户的需求并不十分清楚,必须通过与用户沟通获取用户对软件的需求。第2页,课件共115页,创作于2023年2月第三章软件需求分析需求分析和规格说明是一项十分艰巨复杂的工作。用户与分析员之间需要沟通的内容非常多,在双方交流信息的过程中很容易出现误解或遗漏,也可能存在二义性。因此,不仅在整个需求分析过程中应该采用行之有效的沟通技术、集中精力仔细工作,而且必须严格审查验证需求分析的结果。尽管目前有许多不同的用于需求分析的方法,但是,所有这些分析方法都遵守下述准则:
(1)必须理解并描述问题的信息域。根据这条准则,应该建立
数据模型。
(2)必须定义软件应完成的功能。根据这条准则,应该建立
功能模型。
(3)必须描述作为外部事件结果的软件行为。为此,应该建立
行为模型。
(4)必须对描述信息、功能和行为的模型进行分解。所以应该用
层次方式展示细节。第3页,课件共115页,创作于2023年2月软件需求分析的主要阶段:1.问题分析2.问题评估和方案综合3.建模4.规约5.复审
第三章软件需求分析在这个阶段,系统分析员的焦点:是“做什么?(what)”而不是“怎样做?(how)”第4页,课件共115页,创作于2023年2月第三章软件需求分析通过问题分析与方案综合,完成以下任务:①确定对系统的综合要求系统的综合要求主要指系统的功能性需求和非功能性需求。
②分析系统的数据要求任何一个软件系统本质上都是信息处理系统,所必须处理的信息和应该产生的信息在很大程度上决定了系统的面貌,对软件设计有深远影响,因此,分析系统的数据要求是必须的。③导出系统的逻辑模型综合系统的综合要求和数据要求,可以导出系统的逻辑模型。通常用数据流图、实体-联系图、状态转换图、数据字典和主要的处理算法描述这个逻辑模型。④修正系统开发计划根据在分析过程中获得的对系统的更深入更具体的了解,可以比较准确地估计系统的成本和进度,修正以前所制定的开发计划。第5页,课件共115页,创作于2023年2月§2需求获取2.1需求获取的目的清楚地理解所要解决的问题,完整地获取用户需求。需求获取面临的挑战:(1)问题空间的理解(2)人与人之间的通信(3)需求的不断变化第三章软件需求分析2.2需求获取方法①访谈(与用户交流或沟通)访谈是最早开始使用的获取用户需求的一种技术,也是迄今为止仍然广泛使用的需求分析技术。第6页,课件共115页,创作于2023年2月第三章软件需求分析访谈分为正式访谈和非正式访谈两种。正式访谈:系统分析员提出一些事先准备好的具体问题询问用户。非正式访谈:分析员提出一些用户可以自由回答的开放性问题,以鼓励被访问人员说出自己的想法。当需要调查大量人员的意见时,分发调查表是一个十分有效的方法。后面将给出一个调查表的例子。情景分析技术也是常用的一种方法。所谓情景分析就是对用户将来使用目标系统解决某个具体问题的方法和结果进行分析。情景分析技术的用处主要体现在下述两个方面:
(1)在某种程度上演示目标系统的行为,从而便于用户理解,而且还可能进一步揭示出一些分析员目前还不知道的需求。
(2)由于情景分析较易为用户所理解,使用这种技术能保证用户在需求分析过程中始终扮演一个积极主动的角色。需求分析的目标是获知用户的真实需求,而这一信息的唯一来源是用户,因此,让用户积极主动地开展工作是需求分析工作获得成功的关键。第7页,课件共115页,创作于2023年2月第三章软件需求分析②面向数据流自顶向下求精软件系统本质上是信息处理系统,而任何信息处理系统的基本功能都是把输入数据转变成需要的输出信息。数据决定了需要的处理和算法,是需求分析的出发点。在可行性研究阶段许多实际的数据元素被忽略了,在需求分析阶段必须详细定义这些数据元素。
结构化分析方法就是面向数据流自顶向下逐步求精进行需求分析的方法。通过可行性研究已经得出了目标系统的高层数据流图,需求分析的目标之一就是把数据流和数据存储定义到元素级。为了达到这个目标,通常从数据流图的输出端着手分析,这是因为系统的基本功能是产生这些输出,输出数据决定了系统必须具有的最基本的组成元素。系统输入数据输出数据第8页,课件共115页,创作于2023年2月第三章软件需求分析输出数据是由哪些元素组成的呢?通过调查访问不难搞清这个问题。那么,每个输出数据元素又是从哪里来的呢?既然它们是系统的输出,显然它们或者是从外面输入到系统中来的,或者是通过计算由系统中产生出来的。沿数据流图从输出端往输入端回溯,应该能够确定每个数据元素的来源,与此同时也就初步定义了有关的算法。但是,可行性研究阶段产生的是高层DFD,许多具体的细节没有包括在里面,因此沿DFD回溯时常常遇到下述问题:
(1)为了得到某个数据元素,可能需要用到DFD中目前还没有的数据元素;(2)获得这些数据元素需要用的算法尚不完全清楚。为了解决这些问题,往往需要向用户和其他技术人员请教,以便使分析员对目标系统有更深的认识,系统中有更多的数据元素被划分,有更多的算法被清楚地描述。通常用DD描述分析过程中得到的相关数据元素,用IPO图等描述相关算法。通过分析而补充的数据流、数据存储和处理,均内被添加到DFD的适当位置上。第9页,课件共115页,创作于2023年2月第三章软件需求分析上述分析过程中得出的结果必须请用户仔细进行复查,DFD是帮助复查的极好工具。从输入端开始,分析员借助DFD、DD和IPO图向用户解释输入数据是如何转变为输出数据的。这些解释集中反映了通过需求分析系统分析员所获得的对目标系统的认识。这些认识正确吗?有没有遗漏?用户通过倾听分析员的报告,并及时纠正和补充相关意见。复查过程验证了已知的元素,补充了未知的元素,填补了文档中的空白。反复进行上述分析过程,分析员就越来越深入地定义了系统中的数据和系统应该完成的功能。为了追踪更详细的数据流,分析员应该把DFD扩展到更低层次。通过功能分解可以完成DFD的细化。对DFD细化后可得到一组新的DFD,不同系统元素之间的关系也变得更清楚了。对这组新DFD的分析追踪可能会产生新的问题,这些问题的答案也可能会在DD中增加一些新条目,并且可能导致新的或精化的算法描述。第10页,课件共115页,创作于2023年2月第三章软件需求分析经过上述问题与解答的反复循环,分析员能够越来越深入地定义目标系统,并最终得到对系统数据和功能要求的满意了解。下图粗略地概括了上述分析过程。面向数据流自顶向下求精过程第11页,课件共115页,创作于2023年2月第三章软件需求分析③简易的应用规格说明技术使用传统的访谈或面向数据流自顶向下求精方法定义需求时,用户处于被动地位而且往往有意无意地与开发者区分“彼此”。由于不能像同一个团队的人那样齐心协力地识别和精化需求,这两种方法的效果有时并不理想。为了解决上述问题,人们研究出一种面向团队的需求收集法,称为简易的应用规格说明技术。该方法提倡用户与开发者密切合作,共同标识问题,提出解决方案要素,商讨不同方案并确定基本需求。目前,该技术已经成为信息系统领域使用的主流技术。使用简易的应用规格说明技术分析需求的典型过程如下:首先进行初步访谈,通过用户对基本问题的回答初步确定待求解问题的范围与解决方案。然后开发者和用户分别写出“产品需求”,选定会议的时间和地点,并选举一个负责主持会议的协调人。邀请开发者和用户双方组织的代表出席会议,并在开会前预先把写好的产品需求分发给每位与会者。第12页,课件共115页,创作于2023年2月第三章软件需求分析要求每位与会者在开会的前几天认真审查产品需求,并且列出作为系统环境组成部分的对象、系统将产生的对象以及为了完成系统功能而使用的对象。此外,还要求每位与会者列出操作这些对象或与这些对象交互的服务(即处理或功能)。最后还应该列出约束条件(如成本、规模、完成日期等)和性能标准(如速度、容量等)。并不期望每位与会者列出的内容都是毫无遗漏的,但是,希望能准确地表达出每个人对目标系统的认识。会议开始后,讨论的第一个问题是:是否需要这个新产品?一旦大家都认为需要这个新产品,每位与会者就应该把他们在会前准备好的列表展示出来供大家讨论。理想的情况是表中每一项都能单独移动,这样就能方便地删除或增添表项,或组合不同的列表。在这个阶段,严格禁止批评与争论。在展示了每个人针对某个议题的列表之后,大家共同创建一张组合列表。在组合列表中消去了冗余项,加入了在展示过程中产生的新想法,但是并不删除任何实质性内容。第13页,课件共115页,创作于2023年2月第三章软件需求分析针对每个议题的组合列表都建立起来后,由协调人主持讨论这些列表。组合列表将被缩短、加长或者重新措辞,以便更准确地描述将要开发的产品。讨论的目标是:针对每个议题(对象、服务、约束和性能),要创建出一张意见一致的列表。一旦给出了意见一致的列表,就把与会者分成更小的小组,每个小组的工作目标是为每张列表中的项目制定小型规格说明。小型规格说明是对列表中所包含的单词或短语的更准确的说明。然后,每个小组都向全体与会者展示他们制定的小型规格说明,供大家讨论。通过讨论可能会增加或删除一些内容,也可能进一步做些精化工作。在完成了小型规格说明之后,每个与会者都制定出产品的一整套确认标准,并把自己制定的标准提交会议讨论,以创建出意见一致的确认标准。最后,由一名或多名与会者根据会议成果起草完整的软件需求规格说明书。第14页,课件共115页,创作于2023年2月第三章软件需求分析简易的应用规格说明技术并不是解决需求分析阶段遇到的所有问题的“万能灵药”,但是,这种面向团队的需求收集方法确实有许多突出优点:开发者与用户不分彼此,齐心协力,密切合作;即时讨论并求精;有能导出规格说明的具体步骤。第15页,课件共115页,创作于2023年2月第三章软件需求分析④快速建立软件原型快速建立软件原型是最准确、最有效、最强大的需求分析技术。快速原型就是快速建立起来的,旨在演示目标系统主要功能的可运行程序。构建原型的要点是:它应该实现用户看得见的功能(如屏幕显示或打印报表等),省略目标系统的“隐含”功能(如修改文件等)。快速原型应该具备的第一个特性是“快速”。快速原型的目的是尽快向用户提供一个可在计算机上运行的目标系统模型,以便使用户与开发者就“目标系统应该做什么”这一问题尽可能快地达成共识。因此,原型的某些缺陷是可以忽略的,只要这些缺陷不严重地损害原型的功能,不会使用户对产品行为产生误解即可。快速原型应该具备的第二个特性是“容易修改”。若原型第一版不是用户所需要的,就必须根据用户的意见迅速进行修改并构建出原型的第二版,以更好地满足用户需求。在实际工作中,“修改—试用—反馈”过程可能要重复多遍,因此,若修改耗时过多,就势必延误软件开发时间。第16页,课件共115页,创作于2023年2月第三章软件需求分析为了快速地构建和修改原型,通常使用下述三种方法和工具:
(1)第四代技术第四代技术包括众多数据库查询和报表语言、程序和应用系统生成器以及其它非常高级的非过程语言。第四代技术使得软件工程师能够快速地生成可执行代码,是较理想的快速构建原型的工具。
(2)可重用的软件构件(组件)
用一组已有的组件来装配原型,而不是从头构造。组件可以是数据结构(或数据库),或软件体系结构(即程序),或过程(即模块)。组件必须被设计成可能重用的。应该注意,现有软件可以被用作“新的或改进的”产品的原型。
(3)形式化规格说明和原型环境人们已经研究出许多形式化规格说明语言和工具用于替代自然语言来描述规格说明,并且正在开发交互式环境,以便可以调用自动工具,把基于形式语言的规格说明翻译成可执行的程序代码,用户能够使用可执行的原型代码去进一步精化形式化的规格说明。第17页,课件共115页,创作于2023年2月例如,某出版社系统的信息调查表可设计如下:编号提出问题1您在哪个部门工作?2出版业务流程是什么?3您每日都处理那些文件、数据、报表?4工作中手工处理特别麻烦的事情是什么?5工作中手工处理什么问题解决不了?影响效率的问题有哪些?6您认为提高工作效率,节省工作时间,减轻工作强度可采取哪些办法?7您的部门需要成本核算和统计的内容有哪些?8您的部门采用计算机管理工作情况如何?9如何改进业务流程使之更合理?10哪些问题是目前传统手工方法根本无法解决的?11出版社计算机管理信息系统需要解决什么问题?第三章软件需求分析第18页,课件共115页,创作于2023年2月2.3需求获取的内容
1.用户需求分类
(1)功能性需求定义了系统做什么(描述系统必须支持的功能和过程)
(2)非功能性需求(技术需求):
定义了系统工作时的特性(描述操作环境和性能目标)第三章软件需求分析(1)功能(2)性能(3)环境(4)界面(5)用户或人的因素
2.两类需求包括的内容(6)文档(7)数据(8)资源(9)安全保密(10)软件成本消耗与开发进度(11)质量保证第19页,课件共115页,创作于2023年2月(1)功能需求
系统做什么?系统何时做什么?系统何时及如何修改或升级?(2)性能需求
软件开发的技术性指标,例如:存储容量限制执行速度、响应时间吞吐量第三章软件需求分析(3)环境需求
硬件设备:机型、外设、接口、地点、分布、温度、湿度、磁场干扰等软件:操作系统、网络、数据库第20页,课件共115页,创作于2023年2月(4)界面需求
有来自其它系统的输入吗?到自其它系统的输出吗?对数据格式有规定吗?对数据存储介质有规定吗?第三章软件需求分析(5)用户或人的因素
用户类型?各种用户熟练程度?需受何种训练?用户理解、使用系统的难度?用户错误操作系统的可能性?(6)文档需求需哪些文档?文档针对哪些读者?第21页,课件共115页,创作于2023年2月(7)数据需求输入、输出数据的格式?接收、发送数据的频率?数据的准确性和精度?数据流量?数据需保持的时间?(8)资源需求软件运行时所需的数据、软件、内存空间等资源。软件开发、维护所需的人力、支撑软件、开发设备等。第三章软件需求分析(9)安全保密要求需对访问系统或系统信息加以控制吗?如何隔离用户之间的数据?用户程序如何与其它程序和操作系统隔离?系统备份要求?第22页,课件共115页,创作于2023年2月(10)软件成本消耗与开发进度需求开发有规定的时间表吗?软硬件投资有无限制?第三章软件需求分析(11)质量保证系统的可靠性要求?系统必须监测和隔离错误吗?规定系统平均出错时间?出错后,重启系统允许的时间?系统变化如何反映到设计中?维护是否包括对系统的改进?系统的可移植性?第23页,课件共115页,创作于2023年2月第三章软件需求分析也可以按如下方式对需求进行分类:
1.功能需求功能需求确定系统必须提供的服务。通过需求分析应该划分出系统必须完成的所有功能。
2.性能需求性能需求确定系统必须满足的定时约束或容量约束,通常包括速度(响应时间)、信息量速率、主存容量、磁盘容量、安全性等。
3.可靠性和可用性需求可靠性需求定量地指定系统的可靠性。可用性与可靠性密切相关,它量化了用户可以使用系统的程度。
4.出错处理需求这类需求说明系统对环境错误应该怎样响应。例如,如果它接收到从另一个系统发来的违反协议格式的消息,应该做什么?需要注意的是,上述这类错误并不是由该应用系统本身造成的。通常,“出错处理”是指当应用系统发现自己犯下一个错误时所应采取的行动。应该有选择地提出这类出错处理需求,因为我们的目的是开发出正确的系统,而不是用无休止的出错处理代码掩盖自己的错误。第24页,课件共115页,创作于2023年2月第三章软件需求分析
5.接口需求接口需求描述应用系统与它的环境通信的格式。常见的接口需求有:用户接口需求;硬件接口需求;软件接口需求;通信接口需求。
6.约束设计约束或实现约束描述在设计或实现应用系统时应遵守的限制条件。在需求分析阶段提出这类需求,并不是要取代设计(或实现)过程,只是说明用户或环境强加给项目的限制条件。常见的约束有:精度;工具和语言约束;设计约束;应该使用的标准;应该使用的硬件平台。
7.逆向需求逆向需求说明软件系统不应该做什么。理论上有无限多个逆向需求,我们应该仅选取能澄清真实需求且可消除可能发生的误解的那些逆向需求。
8.将来可能提出的要求应该明确地列出那些虽然不属于当前系统开发范畴,但是据分析将来很可能会提出来的要求。这样做的目的是,在设计过程中对系统将来可能的扩充和修改预做准备,以便一旦确实需要时能比较容易地进行这种扩充和修改。第25页,课件共115页,创作于2023年2月计算机学科的发展计算机科学(CS)计算机科学(CS)计算机工程(CE)软件工程(SE)信息系统(IS)计算学科(computingdiscipline)
计算学科是研究通过在计算机上建立模型并模拟物理过程来进行科学调查和研究的学科。
3.分析建模及其图形工具第三章软件需求分析第26页,课件共115页,创作于2023年2月计算机科学与技术学科的方法论学科的3个形态理论抽象(模型化)设计重复出现的概念绑定(binding)概念与形式模型一致性和完备性抽象层次重用……典型的学科方法:数学方法系统科学方法……
在处理复杂事务、构造系统、隐藏细节和获取重复模式等方面使用抽象,通过具有不同层次的细节和指标的抽象,能够表达一个实体和系统第三章软件需求分析第27页,课件共115页,创作于2023年2月抽象(模型化)模型(model)模型:现实世界某些重要方面的符号表示。有时使用术语“抽象”来表示模型,因为可以从现实世界中抽象出对我们特别有用的信息。第三章软件需求分析抽象源于实验科学,其主要要素为数据采集方法和假设的形式说明、模型的构造与预测实验结果分析。在构造算法的数据结构和系统结构等模型时,使用此过程。抽象的结果是概念符号模型。为了更好地理解复杂事物,人们常常采用建立事物模型的方法。所谓模型,就是为了理解事物而对事物做出的一种抽象,是对事物的一种无歧义的书面描述。通常,模型由一组图形符号和组织这些符号的规则组成。第28页,课件共115页,创作于2023年2月
4.需求分析的步骤当前系统目标系统物理模型逻辑模型逻辑模型物理模型模型化抽象化具体化实例化怎么做做什么当前系统目标系统需求定义第三章软件需求分析第29页,课件共115页,创作于2023年2月模型是对对象系统的形式化的特征抽象,概括或近似地表示;构造模型的过程是一个抽象、分析的过程。对象系统模型系统抽象(映射)模型应用模型构造的过程第三章软件需求分析
5.逻辑模型和物理模型第30页,课件共115页,创作于2023年2月第三章软件需求分析逻辑模型(本质模型、概念模型)现行系统目标系统描述重要的业务功能,不关心系统是如何实施的。描述现实系统是如何在物理上实现的。描述新系统的主要业务功能和用户新的需求,无论系统该如何实施。描述新系统是如何实施的(包括技术)。物理模型(实施模型、技术模型)第31页,课件共115页,创作于2023年2月①ER图第三章软件需求分析
6.几个常用的图形工具实体-联系(ER)图是用来描述数据结构及其关联关系的常用工具。为了把用户的数据要求清楚、准确地描述出来,系统分析员通常建立一个概念性的数据模型(也称为信息模型)。概念性数据模型是一种面向问题的数据模型,是按照用户的观点对数据建立的模型。它描述了从用户角度看到的数据,它反映了用户的现实环境,而且与软件系统中的实现方法无关。数据模型中包含3种相互关联的信息:数据对象、数据对象的属性及数据对象彼此间相互连接的关系。第32页,课件共115页,创作于2023年2月第三章软件需求分析数据对象
数据对象是对软件必须理解的复合信息的抽象。所谓复合信息是指具有一系列不同性质或属性的个体事物,仅有单个值的事物(例如,宽度)不是数据对象。数据对象可以是外部实体(例如,产生或使用信息的任何事物)、事物(例如,报表)、行为(例如,打电话)、事件(例如,响警报)、角色(例如,教师、学生)、单位(例如,会计科)、地点(例如,仓库)或结构(例如,文件)等。总之,可以由一组属性来定义的实体都可以被认为是数据对象。数据对象彼此间是有关联的,例如,教师“教”课程,学生“学”课程,教或学的关系表示教师和课程或学生和课程之间的一种特定的连接。数据对象只封装了数据而没有对施加于数据上的操作的引用,这是数据对象与面向对象范型中的“类”或“对象”的显著区别。第33页,课件共115页,创作于2023年2月第三章软件需求分析属性属性定义了数据对象的性质。必须把一个或多个属性定义为“标识符”,也就是说,当希望找到数据对象的一个实例时,用标识符属性作为“关键字”(通常简称为“键”)。应该根据对所要解决的问题的理解,来确定特定数据对象的一组合适的属性。联系(关联)数据对象彼此之间相互连接的方式称为联系,也称为关联。联系可分为以下3种类型:
(1)一对一联系(1∶1)
例如,一个部门有一个经理,而每个经理只在一个部门任职,则部门与经理的联系是一对一的。第34页,课件共115页,创作于2023年2月第三章软件需求分析
(2)一对多联系(1∶N)
例如,某校教师与课程之间存在一对多的联系“教”,即每位教师可以教多门课程,但是每门课程只能由一位教师来教。第35页,课件共115页,创作于2023年2月第三章软件需求分析
(3)多对多联系(M∶N)
例如,上图中表示学生与课程间的联系(“学”)是多对多的,即一个学生可以学多门课程,而每门课程可以有多个学生来学。联系也可能有属性。例如,学生“学”某门课程所取得的成绩,既不是学生的属性也不是课程的属性。由于“成绩”既依赖于某名特定的学生又依赖于某门特定的课程,所以它是学生与课程之间的联系“学”的属性。第36页,课件共115页,创作于2023年2月第三章软件需求分析ER图的表示通常,使用实体-联系图(entity-relationshipdiagram)来建立数据模型。可以把实体-联系图简称为ER图,相应地可把用ER图描绘的数据模型称为ER模型。
ER图中包含了实体(即数据对象)、关系和属性等3种基本成分,通常用矩形框代表实体,用连接相关实体的菱形框表示关系,用椭圆形或圆角矩形表示实体(或关系)的属性,并用直线把实体(或关系)与其属性连接起来。上图是某学校教学管理的ER图。人们通常采用实体、联系和属性这3个概念来理解现实问题,因此,ER模型比较接近人的习惯思维方式。此外,ER模型使用简单的图形符号表达系统分析员对问题域的理解,不熟悉计算机技术的用户也能理解它。因此,ER模型可以作为用户与分析员之间有效的交流工具。第37页,课件共115页,创作于2023年2月②数据规范化第三章软件需求分析软件系统经常使用长期保存的各种信息,这些信息通常以一定方式组织并存储在数据库或文件中。为减少数据冗余,避免出现插入异常或删除异常,简化修改数据的过程,通常需要把数据结构规范化。通常用“范式(normalforms)”定义消除数据冗余的程度。第一范式(1NF)数据冗余程度最大,第五范式(5NF)数据冗余程度最小。但是,范式级别越高,存储同样数据就需要分解成更多张表,因此,“存储自身”的过程也就越复杂。第二,随着范式级别的提高,数据的存储结构与基于问题域的结构间的匹配程度也随之下降,因此,在需求变化时数据的稳定性较差。第三,范式级别提高则需要访问的表增多,因此性能(速度)将下降。从实用角度看来,在大多数场合选用第三范式都比较恰当。第38页,课件共115页,创作于2023年2月第三章软件需求分析通常按照属性间的依赖情况区分规范化的程度。属性间依赖情况满足不同程度要求的称为不同范式,满足最低要求的是第一范式,在第一范式中再进一步满足一些要求的为第二范式,其余依此类推。下面给出第一、第二和第三范式的定义:
(1)第一范式每个属性值都必须是原子值,即仅仅是一个简单值而不含内部结构。
(2)第二范式满足第一范式条件,而且每个非关键字属性都由整个关键字决定(而不是由关键字的一部分来决定)。
(3)第三范式符合第二范式的条件,每个非关键字属性都仅由关键字决定,而且一个非关键字属性不能仅仅是对另一个非关键字属性的进一步描述(即一个非关键字属性值不依赖于另一个非关键字属性值)。第39页,课件共115页,创作于2023年2月③状态转换图第三章软件需求分析在需求分析过程中,应该建立起软件系统的行为模型。状态转换图(简称状态图)通过描绘系统的状态及引起系统状态转换的事件来表示系统的动态行为。此外,状态图还指明了作为特定事件的结果系统将做哪些动作(例如,处理数据)。因此,状态图提供了行为建模机制,可以满足需求分析准则的要求。状态状态是任何可以被观察到的系统行为模式,一个状态代表系统的一种行为模式。状态规定了系统对事件的响应方式。系统对事件的响应,既可以是做一个(或一系列)动作,也可以是仅仅改变系统本身的状态,还可以是既改变状态又做动作。在状态图中定义的状态主要有:初态(即初始状态)、终态(即最终状态)和中间状态。在一张状态图中只能有一个初态,而终态则可以有0至多个。第40页,课件共115页,创作于2023年2月第三章软件需求分析状态图既可以表示系统循环运行过程,也可以表示系统单程生命期。当描绘循环运行过程时,通常并不关心循环是怎样启动的。当描绘单程生命期时,需要标明初始状态(系统启动时进入初始状态)和最终状态(系统运行结束时到达最终状态)。事件事件是在某个特定时刻发生的事情,它是对引起系统做动作或(和)从一个状态转换到另一个状态的外界事件的抽象。例如,内部时钟表明某个规定的时间段已经过去,用户移动或点击鼠标等都是事件。简而言之,事件就是引起系统做动作或(和)转换状态的控制信息。第41页,课件共115页,创作于2023年2月第三章软件需求分析符号在状态图中,初态用实心圆表示,终态用一对同心圆(内圆为实心圆)表示。中间状态用圆角矩形表示,可以用两条水平横线把它分成上、中、下3个部分。上面部分为状态的名称,这部分是必须有的;中间部分为状态变量的名字和值,这部分是可选的;下面部分是活动表,这部分也是可选的。
活动表的语法格式如下:事件名(参数表)/动作表达式其中,“事件名”可以是任何事件的名称。在活动表中经常使用下述3种标准事件:entry,exit和do。entry事件指定进入该状态的动作,exit事件指定退出该状态的动作,而do事件则指定在该状态下的动作。需要时可以为事件指定参数表。活动表中的动作表达式描述应做的具体动作。第42页,课件共115页,创作于2023年2月第三章软件需求分析状态图中两个状态之间带箭头的连线称为状态转换,箭头指明了转换方向。状态变迁通常是由事件触发的,在这种情况下应在表示状态转换的箭头线上标出触发转换的事件表达式;如果在箭头线上未标明事件,则表示在源状态的内部活动执行完之后自动地触发转换。
事件表达式的语法如下:
事件说明[守卫条件]/动作表达式其中,事件说明的语法为:事件名(参数表)。守卫条件是一个布尔表达式。如果同时使用事件说明和守卫条件,则当且仅当事件发生且布尔表达式为真时,状态转换才发生。如果只有守卫条件没有事件说明,则只要守卫条件为真状态转换就发生。动作表达式是一个过程表达式,当状态转换开始时执行该表达式。下图给出了状态图中使用的主要符号。第43页,课件共115页,创作于2023年2月第三章软件需求分析第44页,课件共115页,创作于2023年2月第三章软件需求分析层次方框图用树形结构的一系列多层次矩形框描述数据的层次结构。④其他图形工具层次方框图如图所示,层次方框图的顶层是一个单独矩形框,它代表完整的数据结构。下面的各层矩形框代表这个数据的子集,最底层的各个框代表组成这个数据的实际数据元素(不能再分割的元素)。随着结构的精细化,层次方框图对数据结构也描绘得越来越详细,这种模式非常适合于需求分析阶段的需要。系统分析员从对顶层信息的分类开始,沿图中每条路径反复细化,直到确定了数据结构的全部细节时为止。第45页,课件共115页,创作于2023年2月第三章软件需求分析法国计算机科学家Warnier提出了表示信息层次结构的另外一种图形工具。Warnier图也用树形结构描绘信息,但是这种图形工具比层次方框图提供了更丰富的描绘手段。用Warnier图可以表明信息的逻辑组织,它可以指出一类信息或一个信息元素是重复出现的(如下图中,操作系统有P1种),也可以表示特定信息在某一类信息中是有条件地出现的。因为重复和条件约束是说明软件处理过程的基础,所以很容易把Warnier图转变成软件设计的工具。
Warnier图第46页,课件共115页,创作于2023年2月第三章软件需求分析
IPO图是输入、处理、输出图的简称,它是美国IBM公司发展完善起来的一种图形工具,能够方便地描绘输入数据、对数据的处理和输出数据之间的关系。
IPO图
IPO图的基本形式是在左边的框中列出有关的输入数据,在中间的框内列出主要的处理,在右边的框内列出产生的输出数据。处理框中列出处理的次序暗示了执行的顺序,但是用这些基本符号还不足以精确描述执行处理的详细情况。在IPO图中,还用类似向量符号的粗大箭头清楚地指出数据通信的情况。下面给出IPO图的一个例子,通过这个例子不难了解IPO图的用法。第47页,课件共115页,创作于2023年2月第三章软件需求分析基本的IPO图第48页,课件共115页,创作于2023年2月第三章软件需求分析一种改进的IPO图(也称为IPO表),如右图所示。这种图中包含某些附加信息,在软件设计过程中将比原始的IPO图更有用。在需求分析阶段可以使用IPO图简略地描述系统的主要算法(即数据流图中各个处理的基本算法)。当然,在需求分析阶段,IPO图中的许多附加信息暂时还不具备,但是在软件设计阶段可以进一步补充修正这些图,作为设计阶段的文档。这正是在需求分析阶段用IPO图作为描述算法的工具的重要优点。第49页,课件共115页,创作于2023年2月第三章软件需求分析通过需求分析除了创建分析模型之外,还应该写出软件需求规格说明书,它是需求分析阶段得出的最主要的文档。通常用自然语言完整、准确、具体地描述系统的数据要求、功能需求、性能需求、可靠性和可用性要求、出错处理需求、接口需求、约束、逆向需求以及将来可能提出的要求。自然语言的规格说明具有容易书写、容易理解的优点,为大多数人所欢迎和采用。
7.软件需求规格说明为了消除用自然语言书写的软件需求规格说明书中可能存在的不一致、歧义、含糊、不完整及抽象层次混乱等问题,有些人主张用形式化方法描述用户对软件系统的需求。关于形式化说明技术,请大家自己阅读有关书籍。第50页,课件共115页,创作于2023年2月2.4需求建模建模的原因:在建模过程中了解系统;通过抽象降低复杂性;有助于回忆所有的细节;有助于开发小组间的交流;有助于与用户的交流;为系统的维护提供文档。模型的作用模型化或模型方法是通过抽象、概括和一般化,把研究的对象或问题转化为本质(关系或结构)相同的另一对象或问题,从而加以解决的方法。第三章软件需求分析模型的类型数学模型描述模型图形模型模型化方法要求所建立的模型能真实反映所研究对象的整体结构、关系或某一过程、某一局部、某一侧面的本质特征和变化规律。第51页,课件共115页,创作于2023年2月需求分析过程示意(1)通过对业务过程的调查,获得当前系统的物理模型
学生学生教务科张三会计室李四出纳员王五教材科赵六购书申请购书单发票领书单书学生购买教材的物理模型第三章软件需求分析学生学生有效性审查开发票开领书单发书购书申请购书单发票领书单书学生购买教材的逻辑模型(2)去掉具体模型中的非本质因素,抽象出当前系统的逻辑模型第52页,课件共115页,创作于2023年2月(3)分析当前系统与目标系统的差别,建立目标系统的逻辑模型计算机售书系统的逻辑模型学生学生审查并开发票开领书单购书单发票领书单无效购书单第三章软件需求分析分析阶段中常用的模型(逻辑模型的图形表示方法)1.数据流图(DFD)2.实体―联系图(ERD)3.类图4.实例图5.时序图6.状态图7.协作图8.事件列表9.数据流定义10.数据元素定义
……第53页,课件共115页,创作于2023年2月第三章软件需求分析SafeHome的第1层DFD开始停止控制面板与用户交互控制面板显示密码电话号码拨音传感器状态显示信息配置请求用户命令和数据配置系统警铃电话线传感器配置信息显示信息和状态监控传感器激活/不激活系统传感器信息密码处理警告类型检验id信息状态信息配置信息第54页,课件共115页,创作于2023年2月客户统计签订一份保险单销售统计客户保险销售人员用例图的例子第三章软件需求分析第55页,课件共115页,创作于2023年2月状态图状态1Do:活动1状态2...事件1[条件1]/动作1结束事件初始事件空闲可视菜单左边按钮按下/显示弹出菜单左边按钮弹起/擦除弹出菜单光标移动/高亮菜单项例如,弹出菜单动作第56页,课件共115页,创作于2023年2月接电话的顺序图送话者交换机远程交换机受话者拿起话筒可通话声拨号码......铃响信号铃响铃响停止信号拿起话筒铃响停止<10deabc{b-a<1}{e-d<5}{c-b<10}路径第三章软件需求分析第57页,课件共115页,创作于2023年2月打印机忙保存打印文件合作图举例队列计算机打印机空闲打印文件打印机打印服务器打印文件第三章软件需求分析第58页,课件共115页,创作于2023年2月电梯状态图举例在一楼上升停滞下降回到一楼回一楼想要到达楼层想要到达楼层电梯行程开始向上向上向下第三章软件需求分析第59页,课件共115页,创作于2023年2月F1:航班信息文件={航空公司名称+航班号+起点+终点+日期+起飞时间+降落时间};航空公司名称=2{字母}4;航班号=3{十进制数字}3;字母=“A”…“Z”;十进制数字=“0”…“9”;起点=终点=1{汉字}10;起飞时间=降落时间=时+分;时=“00”…“23”;分=“00”…“59”;日期=年+月+日;年=[2000|2001|…|2009];月=“01”…“12”;日=“01”…“31”。第三章软件需求分析第60页,课件共115页,创作于2023年2月§3结构化分析建摸方法结构化分析(传统建模方法)面向对象分析第三章软件需求分析
1.结构化分析方法(StructuredAnalysis,SA)分析模型的主要目标:描述用户需求建立创建软件设计的基础定义软件完成后可被确认的一组需求需求获取应遵循的三条基本原则:分解抽象投影结构化分析方法是基于数据流技术的分析方法。第61页,课件共115页,创作于2023年2月第三章软件需求分析结构化分析实质上是一种创建模型的活动。为了开发出复杂的软件系统,系统分析员应该从不同角度抽象出目标系统的特性,使用精确的表示方法构造系统的模型,验证模型是否满足用户对目标系统的需求,并在设计过程中逐渐把和实现有关的细节加进模型中,直至最终用程序实现模型。根据结构化分析的准则,需求分析过程应该建立3种模型,它们分别是数据模型、功能模型和行为模型。第62页,课件共115页,创作于2023年2月2.分析模型的结构第三章软件需求分析数据字典数据E-R图状态变迁图加工规约控制规约数据对象描述流图分析模型的元素E-R图(ERD):实体-关系图数据流图(DFD)
指明数据在系统中移动时如何被变换;描述对数据流进行变换的功能;
DFD中每个功能的描述包含在加工规约(小说明)。状态变迁图(STD):
指明作为外部事件的结果,系统将如何动作。数据建模E-R图是数据建模的基础数据字典(DD):模型核心(中心库)第63页,课件共115页,创作于2023年2月3.将分析模型转换为软件设计数据字典数据流图E-R图状态变迁图加工规约控制规约数据对描述象过程设计接口设计数据设计体系结构设计分析模型设计模型第三章软件需求分析第64页,课件共115页,创作于2023年2月过程设计接口设计数据设计体系结构设计将设计模型金字塔倒立的结果是什么?第三章软件需求分析接口设计数据设计体系结构设计过程设计是不是自顶向下的软件设计过程?
这是结构化方法的主要特征之一。针对SA,讨论要点:
DFDDD
其他描述方法第65页,课件共115页,创作于2023年2月功能建模与信息流
信息流模型(DFD)基于计算机的系统外部实体输入信息输出信息外部实体外部实体输入信息外部实体外部实体输出信息输出信息第三章软件需求分析第66页,课件共115页,创作于2023年2月一.数据流图(DFD,DataFlowDiagram)
DFD是描述逻辑模型的图形工具,表示数据在系统内的变化。(1)对考生送来的报名单进行检查;(2)对合格的报名单编好准考证号后将准考证送给考生,并将汇总后的考生名单送给阅卷站;(3)对阅卷站送来的成绩单进行检查,并根据考试中心制定的合格标准审定合格者;(4)制作考生通知单(含成绩及合格/不合格标志)送给考生;(5)按地区进行成绩分类统计和试题难度分析,产生统计分析表。实例:考务处理系统
功能描述如下:第三章软件需求分析第67页,课件共115页,创作于2023年2月考务处理系统的分层DFD考生考务处理系统考试中心阅卷站不合格报名单报名单准考证考生通知单成绩清单合格标准错误成绩清单考生名单统计分析表顶层DFD(可行性分析阶段的结果)第三章软件需求分析第68页,课件共115页,创作于2023年2月0层数据流图(一级细化,分析阶段的结果)第三章软件需求分析1登记报名单报名单准考证2统计成绩不合格报名单考生通知单统计分析表考生名册合格标准考生名单错误成绩清单成绩清单第69页,课件共115页,创作于2023年2月一层数据流图(a)(二级细化,分析阶段的结果)1.1检查报名单报名单准考证1.2编准考证号不合格报名单考生名册考生名单合格报名单1.3登记考生第三章软件需求分析第70页,课件共115页,创作于2023年2月一层数据流图(b)(二级细化)2.1检查成绩清单2.2审定合格者考生名册正确成绩清单2.3制作通知单2.4分析统计成绩2.5分析试题难度试题得分清单考生通知单难度分析表合格标准分类统计表成绩清单错误成绩清单经审定的成绩清单第三章软件需求分析
DFD可以用来表示一个系统或软件在任何层次上的抽象。较大型的软件系统DFD分成多层(子图、父图概念),可以表示数据流和功能的进一步的细节。第71页,课件共115页,创作于2023年2月S2132.22.12.33.13.2顶层(不编号)0层1层第三章软件需求分析第72页,课件共115页,创作于2023年2月数据流和控制流举例(使用Ward和mellor符号)监控固件和操作接口每个固件状态动作警告机器人初始化控制操作命令部件状态缓冲器位置命令开始/停止处理机器人命令机器人命令文件操作设置处理活动记录机器人动作位串第三章软件需求分析第73页,课件共115页,创作于2023年2月数据和控制模型的关系DFD加工规约加工模型DFD控制规约控制模型数据输出数据条件数据输入控制输入控制输出加工激活者第三章软件需求分析第74页,课件共115页,创作于2023年2月SafeHome的控制面板第三章软件需求分析与用户交互SAFEHOMEARMEDPOWER01123456789*0#OFFARAYSTAYMAXTESTBYPASSINSTANTCODECHIMEREADYpanicalarmcheckfireawaystayinstantbypassnotready第75页,课件共115页,创作于2023年2月SafeHome的第0层DFD
SafeHome软件系统控制面板显示用户命令和数据显示信息控制面板传感器传感器状态警铃电话线警告类型电话号码拨音第三章软件需求分析第76页,课件共115页,创作于2023年2月第三章软件需求分析SafeHome的第1层DFD开始停止控制面板与用户交互控制面板显示密码电话号码拨音传感器状态显示信息配置请求用户命令和数据配置系统警铃电话线传感器配置信息显示信息和状态监控传感器激活/不激活系统传感器信息密码处理警告类型检验id信息状态信息配置信息第77页,课件共115页,创作于2023年2月监控传感器的第2层DFD电话号码拨音传感器状态配置数据显示格式配置信息产生警告信息拨号评估设置传感器信息读传感器警告类型传感器id类型传感器id类型定位第三章软件需求分析第78页,课件共115页,创作于2023年2月第三章软件需求分析SafeHome的第1层CFD用户命令和数据切换开关控制面板与用户交互控制面板显示传感器事件显示活动状态(完成、在处理中)配置系统警铃电话线传感器配置信息显示信息和状态监控传感器激活/不激活系统密码处理警告状态闪烁标志警告信号超时第79页,课件共115页,创作于2023年2月与“用户交互”有关与“显示信息&状态”有关与“监视&控制系统”有关与“显示信息&状态”有关SafeHome的状态变迁图读用户输入超时监视系统状态传感器事件行为显示用户反馈与“用户交互”有关开关/切换与“监视&控制系统”有关显示活动状态传感器事件与“显示信息&状态”有关与“监视&控制系统”有关传感器事件传感器事件传感器事件闪烁第三章软件需求分析第80页,课件共115页,创作于2023年2月
DFD中的数据流、数据存储表示某个有组织的数据集合,它们要由SA的其他描述工具-需求字典(数据字典)来描述,包括:词条描述数据结构描述加工逻辑说明
DD是对所有与系统相关的数据元素的一个有组织的列表,以及精确、严格的定义,使得用户和系统分析员对于输入、输出、存储成分和中间计算有共同的理解。数据字典的作用第三章软件需求分析二.数据字典(DD,DataDictionary)
DD中数据结构的描述方式定义式Warnier图巴科斯范式(BNF)第81页,课件共115页,创作于2023年2月F1:航班信息文件={航空公司名称+航班号+起点+终点+日期+起飞时间+降落时间}航空公司名称=2{字母}4
航班号=3{十进制数字}3
字母=“A”…“Z”十进制数字=“0”…“9”起点=终点=1{汉字}10
起飞时间=降落时间=时+分时=“00”…“23”
分=“00”…“59”
日期=年+月+日年=[2003|2004|2005|2006]
月=“01”…“12”
日=“01”…“31”第三章软件需求分析第82页,课件共115页,创作于2023年2月第三章软件需求分析重复项:起点=终点=1{汉字}10
航空公司名称=2{字母}4
航班号=3{十进制数字}3组合项:日期=年+月+日起飞时间=降落时间=时+分选择项:年=[2000|2001|…|2009]原数据项:字母=“A”…“Z”
十进制数字=“0”…“9”
时=“00”…“23”
分=“00”…“59”
月=“01”…“12”
日=“01”…“31”第83页,课件共115页,创作于2023年2月操作符含义描述=定义为+与(顺序结构)
{...}重复(循环结构)〔..|..〕或(选择结构)〔..,..〕(...)任选
m..n界域*...,*注释符定义式中使用的符号第三章软件需求分析限制重复次数举例:{}表示允许重复0至任意次1{}表示至少出现1次3{}3或{}表示恰好重复出现3次333{}5或{}表示允许重复3-5次35第84页,课件共115页,创作于2023年2月数据流条目给出DFD中某个数据流的定义,通常包括:数据流标识;数据流来源;数据流去向;数据流的数据组成;流动属性描述:频率、数据量。第三章软件需求分析购书单发票领书单无效书单学生各班学生用书表数据流条目1审查并开发票2开领书单学生教材存量表第85页,课件共115页,创作于2023年2月数据流条目说明举例数据流名:购书单别名:无简述:学生购书时填写的项目来源:学生去向:加工1“审查并开发票”组成:(学号)+姓名+{书号+数量}数据流量:1000次/周
高峰值:开学期间1000次/天
第三章软件需求分析第86页,课件共115页,创作于2023年2月数据存储条目(数据文件词条)第三章软件需求分析对某个文件的定义,包括:文件名;描述;数据结构;数据存储方式;关键字;存取频率和数据量;安全性要求等。文件名:教材存量表别名:无简述:存放库存所有教材的信息组成:教材名称+教材编号+作者
+版本号+出版日期
+出版社+单价+库存量
+…组织方式:索引文件,以编号为关键字查询要求:要求能够立即查询例如,第87页,课件共115页,创作于2023年2月数据项条目(数据元素词条)数据项是不可再分解的数据单位,包括:名称描述数据类型长度(精度)
取值范围及缺省值计量单位相关数据元素及其结构等。第三章软件需求分析例如,数据项名:教材编号别名:BOOK-No,BOOK-num简述:教材库中的所有教材的编号类型:字符串长度:13取值范围及含义:
第1位:A∼Z(1个字母)第2∼4位:3{十进制数字}3(3位数字)
第5位:.(句点)第6位:1{十进制数字}1(1位数字)第7位:“-”
(破折线)第8∼13位:6{十进制数字}6(序列号)第88页,课件共115页,创作于2023年2月F1:航班信息文件={航空公司名称+航班号+起点+终点+日期+起飞时间+降落时间}航空公司名称=2{字母}4
航班号=3{十进制数字}3
字母=“A”…“Z”
十进制数字=“0”…“9”
起点=终点=1{汉字}10
起飞时间=降落时间=时+分时=“00”…“23”
分=“00”…“59”
日期=年+月+日年=“00”…“99”月=“01”…“12”
日=“01”…“31”第三章软件需求分析第89页,课件共115页,创作于2023年2月存折=户名+所号+帐号+开户日期+性质+(印密)+1{存取行}50户名=2{字母}24所号=“001”..“999”(注:储蓄所编码,规定三位数字)帐号=“00000001”..“99999999”(注:帐号规定由八位数字组成)开户日期=年+月+日性质=“1”..“6”(注:“1”表示普通户,“5”表示工资户等)印密=“0”(注:印密在存折上不显示)存取行=日期+(摘要)+指出+存入+余额+操作+复核年=[2003|2004|2005|2006]月=“01”..“12”
日=“01”..“31”摘要=1{字母}4(注:表明该存取是存?是取?还是换?)支出=金额(注:金额规定不超过9999999.99元)存入=金额余额=金额金额=“0000000.01”..“9999999.99”操作=“00001”..“99999”复核=“00001”..“99999”字母=[“a”..“z”|“A”..“Z”]第三章软件需求分析第90页,课件共115页,创作于2023年2月第二层DFD(0层)
教材购销系统第三章软件需求分析购书单缺书单1销售2采购学生教材存量表F1缺书登记表F2书库保管员进书通知教材入库信息领书单第91页,课件共115页,创作于2023年2月第二层DFD(0层)
教材购销系统第三章软件需求分析DF01-10DF20-021.0销售XSMD2.0采购CGMD学生教材存量表F1缺书登记表F2书库保管员DF02-20DF20-10DF10-0121第92页,课件共115页,创作于2023年2月DD数据流条目说明举例第三章软件需求分析加工条目(加工逻辑说明)加工类条目即数据处理描述,也称为小说明。它描述实现加工的策略,而不是实现加工的细节。小说明可认为是DD的组成部分。也可在DD中定义只说明每个加工的组成,即每个处理分解成多少小处理,而在小说明中详细描述每个处理的处理逻辑。〔图号〕DF01-10/*有效购书单*/DF01-10=学号+姓名+{书号+数量}例如,加工逻辑名:登记报名单编号:1.0激活条件:收到报名单加工逻辑:
{1.1检查报名单+1.2编准考证号+1.3登记考生}执行频率:2000次/日第93页,课件共115页,创作于2023年2月DD定义方法找出所有数据元素(数据流,数据存储,数据项,加工)对数据项分类作结构定义排序DD的分类DD中的命名(遵守系统开发规范规定)第三章软件需求分析DD的实现
(1)人工方法
(2)自动方法
(利用字典管理程序)DD应具特点
(1)通过名字可方便查阅数据定义
(2)无冗余
(3)易更新修改第94页,课件共115页,创作于2023年2月三.小说明(加工逻辑说明的另一种形式)第三章软件需求分析1.描述的内容:
(1)处理逻辑描述基本加工如何把输入数据流变换为输出数据流的加工原则,不涉及具体处理方法。
(2)执行条件
(3)输入
(4)输出
(5)优先级
(6)执行频率
(7)出错处理对策等第95页,课件共115页,创作于2023年2月2.小说明举例例1,加工名:分类采购(CG111MD)编号:1.1.1加工激活条件:受到图书采购员分类、采购操作命令加工逻辑:(1)1.1.1.1预定图书
(2)1.1.1.2外采图书
(3)1.1.1.3赠送图书执行频率:随时
第三章软件需求分析第96页,课件共115页,创作于2023年2月例2,处理名:月票额统计(MHCW713MD)编号:7.1.3激活条件:收到每日售票额信息处理逻辑:1统计月保险金总合月保险金信息=每日日保险金信息之和
2统计月合计月合计信息=每日日合计信息之和执行频率:1次/月第三章软件需求分析第97页,课件共115页,创作于2023年2月3.描述加工逻辑的工具结构化语言判定表判定树第三章软件需求分析1)结构化语言介于自然语言和形式语言之间的语言。结构化语言的特点:无确定语法;可分层、嵌套。第98页,课件共115页,创作于2023年2月处理名:核实订票处理编号:3.2激活条件:收到取订票信息处理逻辑:1.读订票旅客信息文件
2.搜索此文件中是否存在与输入信息中姓名及身份证号相符的项
IF
有
THEN
判断余项是否与文件中信息相符
IF
是THEN
输出已订票信息
ELSE
输出未订票信息
ELSE
输出未订票信息执行频率:实时第三章软件需求分析第99页,课件共115页,创作于2023年2月2)判定表(决策表)描述多条件、多目标动作的形式化工具。例,判定表举例(计算机票折扣率)旅游时间订票量折扣量7-9,12月≤20≤20>20>20
15%
5%
20%
30%条件类别四种条件组合操作条件组合下操作的执行1-6,10,11月第三章软件需求分析第100页,课件共115页,创作于2023年2月处理名:计算折扣率编号:5.3.4激活条件:收到预订票信息处理逻辑:计算折扣率执行频率:实时第三章软件需求分析旅游时间订票量折扣量7-9,12月≤20≤20>20>20
15%
5%
20%
30%1-6,10,11月第101页,课件共115页,创作于2023年2月3)判定树(Decision决策树)
条件1
条件2
结果计7-9,
订票量>20:
15%
算12月
订票量≤20:
5%
折扣1-6,
订票量>20:
30%
量10,11月
订票量≤20:
5%第三章软件需求分析第102页,课件共115页,创作于2023年2月4.结构化分析实施步骤1.确定系统边界,画出系统环境图2.自顶向下,画出各层数据流图3.定义数据字典4.定义小说明第三章软件需求分析第103页,课件共115页,创作于2023年2月5.需求规格说明书
(SoftwareRequirementSpecification,SRS)
SRS是需求分析阶段要完成的文档。
SRS的作用:开发者与用户间事实上的技术合同书开发者下一步设计和编码的基础测试验收目标系统的依据第三章软件需求分析SRS大纲(模板)引言任务概述(项目概述)数据描述(DFD、DD)功能描述接口性能需求属性其它需求第104页,课件共115页,创作于20
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年丁禾青项目投资可行性研究分析报告
- 二零二五年护理服务合同协议涵盖家庭护理与康复训练3篇
- 2025年度面包砖生产工艺改进合作协议4篇
- 2023-2029年中国粉丝经济市场竞争格局及投资前景展望报告
- 2024物流公司与国际快递公司之间的合作协议
- 二零二五年度生态园林苗木采购合作协议3篇
- 二零二五年游泳教练员聘请合同
- 2025年挖掘机械租赁及装卸服务合同范本3篇
- 2025年湘师大新版七年级地理下册月考试卷含答案
- 2025年度旅游汽车租赁合作协议范本3篇
- 项目工程师年终总结课件
- 一年级口算练习题大全(可直接打印A4)
- 电动车棚消防应急预案
- 人力资源战略规划地图
- 2023年河南公务员考试申论试题(县级卷)
- DB35T 2198-2024 工业园区低零碳创建评估准则 福建省市监局
- 不为积习所蔽勿为时尚所惑-如何做一个 好老师 高中主题班会课件
- 托育服务中心项目可行性研究报告
- 中式烹调师四级理论考试题库(重点500题)
- 碳排放管理员 (碳排放核查员)技能考核内容结构表四级、技能考核要素细目表四级
- 物业五级三类服务统一标准
评论
0/150
提交评论