面向数据流的设计方法.ppt
《面向数据流的设计方法.ppt》由会员分享,可在线阅读,更多相关《面向数据流的设计方法.ppt(49页珍藏版)》请在三一办公上搜索。
1、软件工程,教材:主编 曹哲 高诚 中国水利水电出版社,教案:河北工业大学廊坊分院 计算机系 黄南川,ZLL,软件工程,第8章面向数据流的设计方法,本章所述技术用于软件的概要设计描述,包括模块、界面和数据结构的定义,这是所有后续开发的基础。面向数据流的设计方法,即通常所说的结构设计法(Structure Design,简称SD方法),由Yourdon和Constantine等人于1874年提出的,与结构化分析(SA)相衔接,根据对数据流的分析设计软件结构。SD方法突出考虑的是如何建立一个结构良好的程序系统,它的基本思想是将系统设计成相对独立、单一功能的模块组成的结构。整个设计是以数据流为基础,由
2、于数据流图和模块结构图之间有着一定的联系,结构化设计方法可以和需求分析中采用的结构化分析方法很好地衔接。结构化设计方法能恰当地划分模块,按功能由顶向下、由抽象到具体逐步细化,把系统分解为一个多层次的具有独立功能的许多模块组成,一直分解到能简便地用程序实现的一种模块为止。所以,SD方法还能和结构化程序设计(SP)相适应。SD方法是根据数据流图来设计,最终目标是建立软件体系结构的描述,即软件模块的层次结构图。此方法用于软件系统的概要设计,尤其适用于大中型的数据处理系统。因此结构化设计方法得到了广泛的应用。,ZLL,软件工程,8.1 SD方法的设计过程和有关概念,SD方法能方便地将数据流图转换为软件
3、结构,其过程分为五步:1 确定信息流的类型;2 划定流界;3 将数据流图映射为程序结构;4 提取层次控制结构;5 通过设计复审和使用启发式策略进 一步精化所得到的结构。在软件设计开始之前,首先要分析数据流图DFD图的系统特性。数据流图一般有两种典型的结构:变换型结构和事务型结构,即变换流和事物流。,ZLL,软件工程,1)变换流,在数据处理问题中,通常会遇到这样一类问题,即从(程序)“外部”取得数据(例如从键盘、磁盘文件等)。对取得的数据进行某种变换,然后再将变换得到的数据传回给“外部“。其中取得数据这一过程称为传人信息(数据)流程,变换数据的过程称为变换信息(数据)流程,传回数据过程称为传出信
4、息(数据)流程。变换流 在基本系统模型(即顶级数据流图)中信息通常以“外部世界”所具有的形式进入系统,经过处理后又以这种形式离开系统。变换型结构是一种线性 状的结构,它可以明显 地分成输人、主加工(或称变换、处理)和输出三部分。,ZLL,软件工程,1)变换流,典型的变换流变换流的特点是:经过变换B的数据流一部分先经过变换C到达变换E,然后另一部分经过变换D到达E;即C和D是顺序结构。,ZLL,软件工程,2)事务流,事务流单个数据项称为事务(transaction)沿传入路径(也称接受通道)进入系统,由外部形式变换为内部形式后到达事务中心,事务中心根据数据项计值结果从若干动作路径中选定一条继续执
5、行。可见它是一个选择结构。,事务中心,T,B,事务,C,A,事务流,ZLL,软件工程,图面向数据流的设计,ZLL,软件工程,8.2 变换分析,下面以“家庭保安系统”的传感器监测子系统为例说明变换分析的各个步骤。步骤一、复审基本系统模型 基本系统模型指顶级DFD和所有由外部提供的信息。这一设计步骤是对系统规格说明书和软件需求规格说明书进行评估。这两个文档描述软件界面上信息的流程和结构。,ZLL,软件工程,“家庭保安系统”的顶级数据流图,警报类别,家庭保安系统软件,控制面板,显示器,警报器,电话线,传感器,用户命令,显示信息,传感数据,电话拨号音频,ZLL,软件工程,“家庭保安系统”的第一级DFD
6、,电话拨号音频,配置数据,配置 数据,配置数据,用户命令处理,显示信息和状态,传感器监测,系统配置,控制面板,显示器,警报器,电话线,传感器,配置信息,配置 命令,启动/停止命令,原口令,有效口令,传感器信息,报警类别,传感数据,显示 信息,用户命令,口令,启动/停止系统和状态,启动或停止消息,口令核对,用户交互子系统,图8-5,ZLL,软件工程,8.2 变换分析,步骤二、复审和精化软件数据流图 这一步主要是对软件需求规格说明书中的分析模型进行精化,直至获得足够详细的DFD。例如,由“传感器监测子系统”的第一级和第二级DFD进一步推导出第三级数据流图,此时,每个变换对应一个独立的功能,可以用一
7、个具有较高内聚度的模块实现,至此已有足够的信息可用于设计“传感器监测子系统”的程序结构,精化过程亦可结束。,ZLL,软件工程,“传感器监测子系统”的第二级DFD,传感器信息,传感器标志的类型和位置,传感数据,警报类别,警报数据,显示格式,产生警报信号,电话拨号,异常数据判别,读取传感数据,配 置 信 息,配置数据,传感器标识类型,电话号码,电话拨号音频,图8-6,ZLL,软件工程,“传感器监测子系统”的第三级DFD,配 置 信 息,警报条件码传感器标志定时信息,传感数据,电话号码对应的音频,电话拨号音频,传感器信息,号码表,电话号码,读取传感数据,获取响应信息,建立警报条件,选择电话号码,连通
8、电话网,产生拨号脉冲,产生警报信号,格式化显示,产生显示,传感器标志的类型和位置,格式化标志的类型和位置,置传感器标识,警报数据,警报类别,配 置 数 据,图8-7,ZLL,软件工程,8.2 变换分析,步骤三、确定DFD的特性,判定它为变换流还是事务流。以图87所示DFD为例,数据沿一个传入路径进来,沿三个传出路径离开,没有明显的事务中心,因此,该信息流应属变换流。步骤四、划定输入流和输出流的边界,孤立变换中心,即找出系统的主加工,确定逻辑输入和逻辑输出。,ZLL,软件工程,这一步我们暂不考虑数据流图中的一些支流,如出错处理等。如果设计人员的经验比较丰富,对该系统的需求又很熟悉,则决定哪些加工
9、是系统的主加工是比较容易的,在几股数据流的汇合处往往是系统的主加工。如果一时不能确定系统的主加工在哪里,则可以先找出逻辑输入和逻辑输出。我们从系统边界的物理输入端开始,一步步向中间移动,直至达到这样一个数据流、它不能再被看作为系统的输入,则其前一个数据流就是系统的逻辑输入,换句话说,离物理输入端最远的,但仍可被看作是系统的输入的那个数据流就是逻辑输入。同样,从物理输出端开始,一步步向中间移动,也可以找出离物理输出端最远的,但仍可被看作是系统的输出的那个数据流就是逻辑输出。在逻辑输入和逻辑输出之间,就是系统的主加工变换中心。再用虚线划分出流界,DFD的三部分就确定了。8-7图中的流边界如虚线所示
10、。,ZLL,软件工程,8.2 变换分析,步骤五、执行“一级分解”(first level factoring)一级分解的目标是导出具有三个层次的程序结构,顶层为主控模块;中层模块控制、协调底层的工作;底层模块执行输入、计算和输出功能。系统的主加工(变换流控制模块,对内部形式数据进行加工、处理)决定了程序结构的“顶层”模块,它抽象地描述了完成整个程序要做的工作。因此主加工确定以后,就决定了主模块的位置,即软件的顶层结构。,ZLL,软件工程,8.2 变换分析,然后,我们按输入、变换、输出等分支设计模块结构的第一层(中层模块控制、协调底层的工作):为逻辑输入设计一个输入模块,它的功能是向主模块提供数
11、据(输入流控制模块,接收所有输入数据);为逻辑输出设计一个输出模块,它的功能是将主模块提供的数据输出(输出流控制模块,产生输出数据);为主加工设计一个变换模块,它的功能是将逻辑输入变换成逻辑输出。并且,第一层模块同主模块之间传送的数据应该同数据流图相对应。,ZLL,软件工程,ZLL,软件工程,8.2 变换分析,程序结构可用Yourdon结构图表示。结构图中,方框代表模块,框内名称表示模块的功能;方框之间的有向边(无二义时也可用无向边)表示模块间的调用关系。调用模块上无标志表示顺序调用:从左至右;菱形表示选择调用;弧形箭头表示循环调用。但本书后面除了顺序调用外,并没有遵循这些规定。,a,c,b,
12、a,c,b,a,b,a)顺序调用 b)选择调用 c)循环调用,ZLL,软件工程,8.2 变换分析,图8-8是一个简单三叉结构,实际处理大型系统的复杂数据流时,可能需要多个模块对应一个模块的功能。“一级分解”总的原则是,在完成控制功能并保持低耦合度、高内聚度的前提下尽可能地减少模块的数量。图8-9是“传感器监测子系统”一级分解,其中控制模块的名字概括了所有下属模块的功能。,ZLL,软件工程,8.2 变换分析,一级分解,输入流,变换流,变换流控制模块,输入流控制模块,输出流,主控模块,输出流控制模块,A,B,C,D,E,F,G,H,图8-8,ZLL,软件工程,传感器监测子系统一级分解结果,警报条件
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 面向 数据流 设计 方法
链接地址:https://www.31ppt.com/p-4950153.html