软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模

上传人:E**** 文档编号:89542533 上传时间:2019-05-27 格式:PPT 页数:66 大小:1.61MB
返回 下载 相关 举报
软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模_第1页
第1页 / 共66页
软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模_第2页
第2页 / 共66页
软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模_第3页
第3页 / 共66页
软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模_第4页
第4页 / 共66页
软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模_第5页
第5页 / 共66页
点击查看更多>>
资源描述

《软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模》由会员分享,可在线阅读,更多相关《软件工程 教学课件 PPT 作者 郑人杰 马素霞 麻志毅 第3章 结构化分析建模(66页珍藏版)》请在金锄头文库上搜索。

1、第2部分 结构化软件开发方法,第3章 结构化分析建模,3.1 软件需求分析阶段的任务,可以把软件需求分析阶段的工作分为4个步骤,即获取需求、分析需求、定义需求和验证需求,如图所示。,软件需求分析阶段的工作步骤,3.1 软件需求分析阶段的任务,需求获取 通过启发、引导从客户(或用户)那里得到的原始需求是他们的业务要求(needs),简称为N。 这是分析之前获取的需求,其中可能存在一些实际问题,这些问题只有通过分析才能得到解决,直接把获取的需求作为软件设计阶段的依据将会导致严重的后果。,3.1 软件需求分析阶段的任务,需求分析 认真研究获取的需求,必须考虑以下几方面: (1) 完整性:每项获取的需

2、求都应给出清楚的描述,使得软件开发工作能够取得设计和实现该功能所需要的全部必要信息。 (2) 正确性:获取的每项需求必须是准确无误的,并且需求描述无歧义性。 (3) 合理性:各项需求之间、软件需求与系统需求之间应是协调一致的,不应存在矛盾和冲突。,3.1 软件需求分析阶段的任务,需求分析 (4) 可行性:包括技术可行性 、经济可行性 、社会可行性 。 (5) 充分性:获取的需求是否全面、周到。,3.1 软件需求分析阶段的任务,需求分析 由于分析的过程会对获取的需求做部分调整,也即从获取的需求N中去掉了一些a,又补充了一些c,从而得到的是分析的需求R1(b+c)。,3.1 软件需求分析阶段的任务

3、,需求定义 将已经过分析的需求清晰、全面、系统、准确地描述成为正式的文档,这一步定义需求的工作就是编写需求规格说明。,3.1 软件需求分析阶段的任务,需求验证 为了确保已定义的需求(需求规格说明)准确无误,并能为客户(或用户)理解和接受,需要对其进行严格的评审。,3.2 结构化分析方法简介,结构化分析方法 传统的分析建模方法称为结构化分析(structured analysis,SA)方法。 最有代表性的是一种面向数据流进行需求分析的方法,最初于20世纪70年代由D.Ross提出,后来又经过扩充,形成了今天的结构化分析方法的框架。,3.2 结构化分析方法简介,结构化分析模型 结构化分析方法是一

4、种建模技术,它建立的分析模型如图所示。,3.3 功能建模,概念 功能建模的思想就是用抽象模型的概念,按照软件内部数据传递、变换的关系,自顶向下逐层分解,直到找到满足功能要求的所有可实现的软件为止。功能模型用数据流图来描述。,3.3 功能建模,数据流图的基本图形符号,3.3 功能建模,多个数据流之间的关系,3.3 功能建模,环境图 环境图(context diagram)也称为顶层数据流图(或0层数据流图),它仅包括一个数据处理过程,也就是要开发的目标系统。 环境图的作用是确定系统在其环境中的位置,通过确定系统的输入和输出与外部实体的关系确定其边界。,3.3 功能建模,典型的环境图,招生系统需求

5、描述 学校首先公布招生条件,考生根据自己的条件报名,之后系统进行资格审查,并给出资格审查信息; 对于资格审查合格的考生可以参加答卷,系统根据学校提供的试题及答案进行自动判卷,并给出分数及答题信息,供考生查询; 最后系统根据学校的录取分数线进行录取,并将录取信息发送给考生。,3.3 功能建模,招生系统的环境图,3.3 功能建模,数据流图的分层 对于稍微复杂一些的实际问题,在数据流图上常常出现十几个甚至几十个加工,这样的数据流图看起来不直观,不易理解,分层的数据流图能很好地解决这一问题。 按照系统的层次结构进行逐步分解,并以分层的数据流图反映这种结构关系,能清楚地表达和容易理解整个系统。,3.3

6、功能建模,招生系统的分层数据流图,3.3 功能建模,数据流图的分层示意图,3.3 功能建模,实例研究 银行储蓄系统的业务流程: 储户填写的存款单或取款单由业务员键入系统; 如果是存款则系统记录存款人姓名、住址(或电话号码)、身份证号码、存款类型、存款日期、到期日期、利率、密码(可选)等信息,并印出存单给储户; 如果是取款而且开户时留有密码,则系统首先核对储户密码,若密码正确或存款时未留密码,则系统计算利息并印出利息清单给储户。 要求画出分层的数据流图,并细化到2层数据流图。,3.3 功能建模,(1) 识别外部实体及输入输出数据流。 外部实体:储户、业务员。 输入数据:如果需要储户输入密码,储户

7、才直接与系统进行交互。储户填写的存款或取款信息通过业务员键入系统,可以将存款及取款信息抽象为事务。 输出数据:存款单,利息清单。,3.3 功能建模,(2) 画出环境图(顶层数据流图),3.3 功能建模,(3) 画出一层数据流图,3.3 功能建模,(4) 画出二层数据流图 对一层图中的“处理存款”及“处理取款”进行进一步分解,得到二层数据流图,即处理存款的数据流图和处理取款的数据流图。,处理存款的数据流图,3.3 功能建模,(4) 画出二层数据流图,处理取款的数据流图,3.4 数据建模,在结构化分析方法中,使用实体关系建模技术来建立数据模型。 这种技术是在较高的抽象层次(概念层)上对数据库结构进

8、行建模的流行技术。 实体关系模型表示为可视化的实体关系图(entity-relationship diagram,ERD),也称为ER图。 ER图中仅包含3种相互关联的元素:数据对象(实体)、描述数据对象的属性及数据对象彼此间相互连接的关系。,3.4 数据建模,数据对象 数据对象是目标系统所需要的复合信息的表示,所谓复合信息是具有若干不同属性的信息。在ER图中用矩形表示数据对象。 在实际问题中,数据对象(实体)可以是外部实体、事物、角色、行为或事件、组织单位、地点或结构等。,3.4 数据建模,属性 属性定义数据对象的特征,如数据对象学生的学号、姓名、性别、专业等,课程的课程编号、课程名称、学分

9、等。 在ER图中用椭圆或圆角矩形表示属性,并用无向边将属性与相关的数据对象连接在一起。,3.4 数据建模,关系 不同数据对象的实例之间是有关联关系的,在ER图上用无向边表示。 在无向边的两端应标识出关联实例的数量,也称为关联的重数。 从关联重数的角度可以将关联分为种。 (1) 一对一(1:1)关联 (2) 一对多(1:m)关联 (3) 多对多(m:n)关联 实例关联还有“必须”和“可选”之分。,3.4 数据建模,关联数量的表示 在ER图中用圆圈表示所关联的实例是可选的,隐含表示“0”,没有出现圆圈就意味着是必须的。出现在连线上的短竖线可以看成是“1”。,3.4 数据建模,关联关系举例,3.4

10、数据建模,关系的属性 关系本身也可能有属性,这在多对多的关系中尤其常见,如学生和课程之间的关系可起名为“选课”,其属性应该有学期、成绩等。 关系属性的表示:在表示关系的无向边上再加一个菱形框,并在菱形框中标明关系的名字,关系的属性同样用椭圆形或圆角矩形表示,并用无向边将关系与其属性连接起来。,3.4 数据建模,关系的属性,3.4 数据建模,银行储蓄系统的ER图,3.5 行为建模,状态转换图(简称状态图)通过描绘系统的状态及引起系统状态转换的事件,来表示系统的行为。状态图中使用的主要符号如图所示。,3.5 行为建模,状态 状态是任何可以被观察到的系统行为模式,一个状态代表系统的一种行为模式,状态

11、规定了系统对事件的响应方式。 状态可能有:初态(初始状态)、终态(最终状态)和中间态。 在一张状态图中只能有一个初态,而终态则可以有多个,也可以没有。,3.5 行为建模,状态的表示:初态用实心圆表示,终态用牛眼图形表示,中间态用圆角矩形表示。,3.5 行为建模,状态转换 状态图中两个状态之间带箭头的连线称为状态转换。 状态的变迁通常是由事件触发的,在这种情况下应在表示状态转换的箭头线上标出触发转换的事件表达式。 如果在箭头线上未标明事件,则表示在源状态的内部活动执行完之后自动触发转换。,3.5 行为建模,状态转换 下图为计算机应用软件的启动过程,在这个过程中没有外部事件触发,每个状态下的活动完

12、成时,状态发生转换。,3.5 行为建模,事件 事件是在某个特定时刻发生的事情,它是对引起系统做动作或从一个状态转换到另一个状态的外部事件的抽象。事件表达式的语法如下: 事件说明(守卫条件)/动作表达式 (1) 事件说明的语法如下: 事件名(参数表) (2) 守卫条件是一个布尔表达式。如果同时使用守卫条件和事件说明,则当且仅当事件发生且布尔表达式成立时,状态转换才发生。如果只有守卫条件没有事件说明,则只要守卫条件为真,状态转换就发生。 (3) 动作表达式是一个过程表达式,当状态转换开始时执行该表达式。,3.5 行为建模,存款过程的状态图(考虑新开户 ),3.5 行为建模,取款过程的状态图,3.6

13、 数据字典,数据字典以词条方式定义在数据模型、功能模型和行为模型中出现的数据对象及控制信息的特性,给出它们的准确定义,包括数据流、加工、数据文件、数据元素,以及数据源点、数据汇点等。 数据字典成为把3种分析模型黏合在一起的“黏合剂”,是分析模型的“核心”。,3.6 数据字典,词条描述 对于在数据流图中每一个被命名的图形元素均加以定义; 其内容包括图形元素的名字,图形元素的别名或编号,图形元素类别(如加工、数据流、数据文件、数据元素、数据源点或数据汇点等)、描述、定义、位置等。,3.6 数据字典,数据流词条 数据流是数据结构在系统内传播的路径,数据流词条应包括以下几项内容。 数据流名:要求与数据

14、流图中该图形元素的名字一致。 简述:简要介绍它产生的原因和结果。 组成:数据流的数据结构。 来源:数据流来自哪个加工或作为哪个数据源的外部实体。 去向:数据流流向哪个加工或作为哪个数据汇点的外部实体。 流通量:单位时间数据的流通量。 峰值:流通量的极限值。,3.6 数据字典,数据元素词条 数据流图中的每个数据结构都是由数据元素构成的,数据元素是数据处理中最小的、不可再分的单位,它直接反映事物的某一特征。 类型:数据元素分为数字型与文字型。数字型又分为离散值和连续值,文字的类型用编码类型和长度区分。 取值范围:离散值的取值或是枚举的(如3,17,21),或是介于上下界的一组数(如2100);连续

15、值一般是有取值范围的实数集(如0.0100.0)。对于文字型,文字的取值需加以定义。 相关的数据元素及数据结构。,3.6 数据字典,数据存储文件词条 数据存储文件是数据保存的地方。一个数据存储文件词条应有以下几项内容。 文件名:要求与数据流图中该图形元素的名字一致。 简述:简要介绍存放的是什么数据。 组成:文件的数据结构。 输入:从哪些加工获取数据。 输出:由哪些加工使用数据。 存取方式:分为顺序、直接、关键码等不同存取方式。 存取频率:单位时间的存取次数。,3.6 数据字典,加工词条 加工可以使用诸如判定表、判定树、结构化语言等形式表达,主要描述如下。 加工名:要求与数据流图中该图形元素的名

16、字一致。 编号:用以反映该加工的层次和父子关系。 简述:加工逻辑及功能简述。 输入:加工的输入数据流。 输出:加工的输出数据流。 加工逻辑:简述加工程序和加工顺序。,3.6 数据字典,数据源点及数据汇点词条 对于一个数据处理系统来说,数据源点和数据汇点应比较少。 名称:要求与数据流图中该外部实体的名字一致。 简述:简要描述是什么外部实体。 有关数据流:该实体与系统交互时涉及哪些数据流。 数目:该实体与系统交互的次数。,3.6 数据字典,数据结构描述 在数据字典的编制中,分析员最常用的描述数据结构的方式有定义式、Warnier图等。 定义式。在数据流图中,数据流和数据文件都具有一定的数据结构,因此,必须以一种清晰、准确、无二义性的方式来描述数据结构。 Warnier图。Warnier图是表示数据结构的另一种图形工具,它用树形结构来描绘数据结构。,3.6 数据字典,定义式中的符号,3.6 数据字典,定义式举例:存折,3.6 数据字典,存折的定义格式 存折户名所号账号开户日

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号