数据流图的画法

数据流图的画法

数据流图也称为数据流程图date flow diagram , DFD,是一种便于用户理解和分析系统数据流程的图形工具,他摆脱了系统和详细内容,精确的在逻辑上描写叙述系统的功能、输入、输出和数据存储等,是系统逻辑模型的重要组成部分。

数据流图的基本组成成分

数据流:是由一组固定成分的数据组成,表示数据的流向。值得注意的是,数据流图中描写叙述的是数据流,而不是控制流。除了流向数据存储或从数据存储流出的数据不必命名外,每一个数据流必需要有一个合适的名字,以反映该数据流的含义。

加工:加工描写叙述了输入数据流到输出数据之间的变换,也就是输入数据流经过什么处理后变成了输出数据。每一个加工都有一个名字和编号。编号能反映该加工位于分层的数据流图的哪个层次和哪张图中,可以看出它是由哪个加工分解出来的子加工。

数据存储:数据存储表示临时存储的数据。每一个数据存储都有一个名字。

外部实体:外部实体是存在于软件系统之外的人员或组织,他指出数据所须要的发源地或系统所产生的数据的归属地。

                       

    

   外部实体               加工             数据流

分层数据流图的设计方法        

第一步,画子系统的输入输出

把整个系统视为一个大的加工,然后依据数据系统从哪些外部实体接收数据流,以及系统发送数据流到那些外部实体,就能够画出输入输出图。这张图称为顶层图。

第二步,画子系统的内部

把顶层图的加工分解成若干个加工,并用数据流将这些加工连接起来,使得顶层图的输入数据经过若干加工处理后,变成顶层图的输出数据流。这张图称为0层图。从一个加工画出一张数据流图的过程就是对加工的分解。

能够用下述方法来确定加工:

在数据流的组成或值发生变化的地方应该画出一个加工,这个加工的功能就是实现这一变化,也能够依据系统的功能决定加工。

确定数据流的方法

用户把若干数据当作一个单位来处理(这些数据一起到达、一起处理)时,能够把这些数据看成一个数据流。

关于数据存储

对于一些以后某个时间要使用的数据,能够组织成为一个数据存储来表示。

第三步,画加工的内部

把每一个加工看作一个小系统,把加工的输入输出数据流看成小系统的输入输出流。于是能够象画0层图一样画出每一个小系统的加工的DFD图。

第四步,画子加工的分解图

对第三步分解出来的DFD图中的每一个加工,反复第三步的分解过程,直到图中尚未分解的加工都是足够简单的(即不可再分解)。至此,得到了一套分层数据流图。

第五步,对数据流图和加工编号

对于一个软件系统,其数据流图可能有很多层,每一层又有很多张图。为了区分不同的加工和不同的DFD子图,应该对每张图进行编号,以便于管理。

●     顶层图仅仅有一张,图中的加工也仅仅有一个,所以不必为其编号。

●     0层图仅仅有一张,图中的加工号各自是0.1、0.2、…,或者1, 2 。

●     子图就是父图中被分解的加工号。

●     子图中的加工号是由图号、圆点和序号组成,如:1.12,1.3 等等。

应该注意的问题:

1.       应适当的为数据流、加工、数据存储以及外部实体命名,名字应该反映该成分的实际含义,避免使用空洞的名字。

2.       画数据流图,不是画控制流。

3.       一个加工的输出数据流,不应与输入数据流同名,及时他们的组成全然同样。

4.       同意一个加工有多条数据流流向还有一个加工,也同意一个加工有两条同样的输出数据流流向不同的加工。

5.       保持父图与子图的平衡。也就是说,父图中的某加工的输入输出流必须与他的子图的输入输出数据流在数量上和名字上同样。值得注意的是,假设父图中的一个输入(输出)数据流相应于子图中的几个输入(输出)数据流,而子图中组成这些数据流的数据项的全体正好是父图中的这一个数据流,那么他们仍然算是平衡的。

6.       在自顶向下的分解过程中,若一个数据存储首次出现时,仅仅与一个加工有关系,那么这个数据存储应作为这个加工的内部文件而不必画出。

7.       保持数据守恒,也就是,一个加工的全部输出数据流中的数据必须能从该加工的输出流中直接获得,或者通过该加工能产生的数据。

8.       每一个加工必须既有输入数据流,又有输出数据流。

9.       在整套数据流图中,每一个数据存储必须既有读的数据流,又有写的数据流。可是在某张子图中,可能仅仅有读没有写,或者仅仅有写没有读。

特别注意上面的几点,都是考试的目标。近两年考试的内容都集中到2、5、6、8的几点上。

比如:

数据流图(DFD)

      数据流图,简称DFD,是SA方法中用于表示系统逻辑模型的一种工具,它以图形的方式描绘数据在系统中流动和处理的过程,因为它仅仅反映系统必须完毕的逻辑功能,所以它是一种功能模型。

下图是一个飞机机票预订系统的数据流图,它反映的功能是:旅行社把预订机票的旅客信息 (姓名、年龄、单位、身份证号码、旅行时间、目的地等)输入机票预订系统。系统为旅客安排航班,打印出取票通知单(附有应交的账款)。旅客在飞机起飞的前一天凭取票通知单交款取票,系统检验无误,输出机票给旅客。

数据流图的画法转载 - 扬扬 - yang_ping111的博客

3.3.1 基本图形符号

数据流图有四种基本图形符号:

数据流图的画法转载 - 扬扬 - yang_ping111的博客 :箭头,表示数据流;

    〇:圆或椭圆,表示加工;

    = :双杠,表示数据存储;

    □:方框,表示数据的源点或终点。

      (1) 数据流。数据流是数据在系统内传播的路径,因此由一组成分固定的数据组成。如订票单由旅客姓名、年龄、单位、身份证号、日期、目的地等数据项组成。因为数据流是流动中的数据,所以必须有流向,除了与数据存储之间的数据流不用命名外,数据流应该用名词或名词短语命名。

      (2)加工(又称为数据处理)。对数据流进行某些操作或变换。每一个加工也要有名字,一般是动词短语,简明地描写叙述完毕什么加工。在分层的数据流图中,加工还应编号。

      (3)数据存储(又称为文件),指临时保存的数据,它能够是数据库文件或不论什么形式的数据组织。

      (4)数据源点或终点,是本软件系统外部环境中的实体(包含人员、组织或其它软件系统),统称外部实体。一般仅仅出如今数据流图的顶层图。

3.3.2画数据流图的步骤

      (1)首先画系统的输入输出,即先画顶层数据流图。顶层流图仅仅包括一个加工,用以表示被开发的系统,然后考虑该系统有哪些输入数据、输出数据流。顶层图的作用在于表明被开发系统的范围以及它和周围环境的数据交换关系。下图为飞机机票预订系统的顶层图。

数据流图的画法转载 - 扬扬 - yang_ping111的博客

(2)画系统内部,即画下层数据流图。不再分解的加工称为基本加工。一般将层号从0開始编号,採用自顶向下,由外向内的原则。画0层数据流图时,分解顶层流图的系统为若干子系统,决定每一个子系统间的数据接口和活动关系。比如,在上面的机票预订系统按功能可分成两部分,一部分为旅行社预订机票,还有一部分为旅客取票,两部分通过机票文件的数据存储联系起来,0层数据流图如图3-4。

      (3)注意事项。

      ①命名。不论数据流、数据存储还是加工,合适的命名使人们易于理解其含义。

      ②画数据流而不是控制流。数据流反映系统“做什么”,不反映“怎样做”,因此箭头上的数据流名称仅仅能是名词或名词短语,整个图中不反映加工的运行顺序。

      ③一般不画物质流。数据流反映能用计算机处理的数据,并非实物,因此对目标系统的数据流图一般不要画物质流。

      ④每一个加工至少有一个输入数据流和一个输出数据流,反映出此加工数据的来源与加工的结果。

      ⑤编号。假设一张数据流图中的某个加工分解成还有一张数据流图时,则上层图为父图,直接下层图为子图。子图及其全部的加工都应编号。

数据流图的画法转载 - 扬扬 - yang_ping111的博客

⑥父图与子图的平衡。子图的输入输出数据流同父图对应加工的输入输出数据流必须一致,此即父图与子图的平衡。

      ⑦局部数据存储。当某层数据流图中的数据存储不是父图中对应加工的外部接口,而仅仅是本图中某些加工之间的数据接口,则称这些数据存储为局部数据存储。

      ⑧提高数据流图的易懂性。注意合理分解,要把一个加工分解成几个功能相对独立的子加工,这样能够降低加工之间输入、输出数据流的数目,添加数据流图的可理解性。

  图3-6给出了採用这套符号画出的等价于图3-2的DFD。

数据流图的画法转载 - 扬扬 - yang_ping111的博客

3.3.3流程图的实例

数据流图的画法转载 - 扬扬 - yang_ping111的博客

数据流图的画法转载 - 扬扬 - yang_ping111的博客


转载于:https://www.cnblogs.com/mengfanrong/p/4263818.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/291899.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MFC继承表

转载于:https://www.cnblogs.com/Lthis/p/4264967.html

linux之fdisk查看分区和mkfs.ext3删除分区和mount挂载和e2label添加卷标使用总结

一、使用fdisk、mkfs.ext3、和mount、e2lable的原因 有个分区挂载不上,然后需要格式化分区,还需要添加卷标 二、fdisk、mkfs.ext3、mount、e2lable命令介绍 1、fdisk命令介绍 1)、了解分区 分区是将一个硬盘驱动器分成若干个逻辑驱动器,分区是把硬盘连续的区块当做一个…

linux c之strncpy函数和strncmp函数最简单使用总结

1.原型声明: char * strncpy(char *dest,const char *src, size_t n); strncmp() 用来比较两个字符串的前n个字符,区分大小写,其原型为: int strncmp ( const char * str1, const char * str2, size_t n ); 若str1与str2的前n…

阻止你变现的,从来都不是开源许可证

文 | lola_chen出品 | OSC开源社区(ID:oschina2013)之前,《GPL 转闭源?法院判决:一日 GPL 终身 GPL》一文提出一个冷门却又重要的知识点:GPL 许可证之下的开源项目,可以分叉出来闭源…

03-递归

数据结构和算法 基于《算法图解》—Aditya Bhargava和《数据结构》—严蔚敏 第3章 递归 3.1 递归 假设在一堆嵌套的盒子里找钥匙,对比循环和递归。 使用循环解决: #使用while循环:只要盒子堆不是空,就从中取出一个盒子&#x…

linux c之提示format‘%d’ expects argument of type ‘int’, but argument 2 has type ‘long int’ [-Wformat

1、问题 有个long int data;我输出的时候printf("data is %d", data);出现下面警告 自己竟然不知道 长整型怎么打印出来,日了狗。 2、解决办法 md,m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大…

Asp.Net Core部署:早知道,还是docker!以及一点碎碎念

前言AspNetCore技术栈在我们团队里的使用也有一段时间了,之前的部署方式一直是本地编译之后上传可执行文件到服务器,使用supervisor来管理进程这种很原始的方式。参考之前的文章:Asp.Net Core学习笔记:(五)…

04-快速排序

数据结构和算法 基于《算法图解》—Aditya Bhargava 和《数据结构》—严蔚敏 第4章 快速排序 4.1 分而治之 divide and conquer , 简称D&C:一种著名的递归式问题解决方法。 例子1: 假设你是农场主,有一小块土地。要求将这块地均匀地分…

android studio no marked region found along edge Found along top edge

由于种种原因,导致9图已经不是9图格式了,但是在Eclipse里面不会报错,在android studio 里面会报错 Error:9-patch image D:\download\avatar-android-master\avatar-android-master\sample\src\main\res\drawable-hdpi\abc_list_divider_holo…

Linux下安装compsoer ,并使用composer安装laravel

为什么80%的码农都做不了架构师?>>> 1、composer安装 https://getcomposer.org/download/打开composer官网。根据提示linux下可以使用php安装。 php -r "copy(https://getcomposer.org/installer, composer-setup.php);" php -r "if (ha…

AspNetCore在docker部署时遇到一个小坑

哦吼之前刚说了尝试了使用docker来部署AspNetCore应用(Asp.Net Core部署:早知道,还是docker!以及一点碎碎念),结果这才刚上班就遇到问题了 …我这项目用的数据库是Oracle,之前直接运行没啥问题,…

05-散列表

数据结构和算法 基于《算法图解》—Aditya Bhargava 和《数据结构》—严蔚敏 第5章 散列表 假设你在一家杂货店上班。有顾客来买东西时,你得到一个本子中查找价格。如果本子的内容不是按字母顺序来排序的,你可能为查找苹果价格而浏览每一页&#xff0c…

疯狂ios讲义疯狂连载之实现游戏逻辑(2)

13.6.5 定义获取通道的工具方法这里所谓的通道指的是一个方块上、下、左、右4个方向上的空白方块图13.10显示了一个方块四周的通道。图13.10 方块四周的通道下面是获取某个坐标点四周通道的4个方法。程序清单codes/13/Link/Link/sources/board/FKGameService.m13.6.6 没有转折点…

linux之进程间通信--使用信号

一、什么是信号用过Windows的我们都知道,当我们无法正常结束一个程序时,可以用任务管理器强制结束这个进程,但这其实是怎么实现的呢?同样的功能在Linux上是通过生成信号和捕获信号来实现的,运行中的进程捕获到这个信号…

解决Maven工程中报 Missing artifact jdk.tools:jdk.tools

2019独角兽企业重金招聘Python工程师标准>>> 解决方法&#xff1a; 在pom.xml中添加如下依赖&#xff1a; <dependency> <groupId>jdk.tools</groupId> <artifactId>jdk.tools</artifactId> <version>…

回到地球之后,这个男人创建了Ubuntu

文 | 大东出品 | OSC开源社区&#xff08;ID&#xff1a;oschina2013&#xff09;2002 年&#xff0c;莫斯科当地时间 4 月 25 日 9 时 26 分&#xff0c;满载着补给和 3 名宇航员的“联盟-TM 号”航天飞船在“联盟 U”火箭的推进下飞往国际空间站。同行的三人中&#xff0c;年…

Hadoop完全分子式环境搭建—问题及解决办法

Hadoop完全分布式环境搭建 ps:本人是按照尚硅谷的教程搭建的&#xff0c;版本hadoop2.7&#xff0c;centos版本6&#xff0c;一台主机&#xff0c;两台从机。 一&#xff0e;版本问题 1.尽量使用hadoop版本2&#xff0c;尽量不要使用最新版本3。因为会出现无法解决的问题&…

POJ 2135 最小费用最大流

思路&#xff1a; 源->1连费用0 流量2 其它的边 费用w 流量1 n->汇 费用0 流量2 最小费用流 搞定~ //By SiriusRen #include <queue> #include <cstdio> #include <cstring> #include <algorithm> using namespace std; #define N 2010 #def…

06-广度优先搜索:图、队列

数据结构和算法 基于《算法图解》—Aditya Bhargava 和《数据结构》—严蔚敏 第6章广度优先搜索 6.1 简介 广度优先搜索—breadth-first search&#xff0c;BFS. 主要内容图和队列。 广度优先搜索能让你能够找出两样东西之间的最短距离&#xff0c;比如&#xff1a;编写国际跳…

虎年云原生落地技术趋势

今天是立春&#xff0c;虎年第一天。去年我写过一篇 牛年 dotnet云原生技术趋势[1]&#xff0c;今天再来写一篇虎年云原生落地技术趋势&#xff0c;去年局限在.NET 平台上的云原生落地&#xff0c;我今年在去年探索云原生落地的基础上从多语言云原生技术落地的趋势来谈谈。在 2…