数据流程图绘制方法
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据流程图绘制方法
数据流程图(date flow diagram , DFD),是SA方法中用于表示系统逻辑模型的一种工具,它以图形的方式描绘数据在系统中流动和处理的过程,由于它只反映系统必须完成的逻辑功能,所以它是一种功能模型。
一、数据流程图的基本组成成分
数据流:是由一组固定成分的数据组成,表示数据的流向。值得注意的是,数据流程图中描述的是数据流,而不是控制流。除了流向数据存储或从数据存储流出的数据不必命名外,每个数据流必须要有一个合适的名字,以反映该数据流的含义。
数据处理:数据处理描述了输入数据流到输出数据之间的变换,也就是输入数据流经过什么处理后变成了输出数据。每个数据处理都有一个名字和编号。编号能反映该数据处理位于分层的数据流程图的哪个层次和哪张图中,能够看出它是由哪个数据处理分解出来的子数据处理。
数据存储:数据存储表示暂时存储的数据。每个数据存储都有一个名字。
外部实体:外部实体是存在于软件系统之外的人员或组织,他指出数据所需要的发源地或系统所产生的数据的归属地。
二、分层数据流程图的设计方法
1、画子系统的输入输出
把整个系统视为一个大的加工,然后根据数据系统从哪些外部实体接收数据流,以及系统发送数据流到那些外部实体,就可以画出输入输出图。这张图称为顶层图。
2、画子系统的内部
把顶层图的加工分解成若干个加工,并用数据流将这些加工连接起来,使得顶层图的输入数据经过若干加工处理后,变成顶层图的输出数据流。这张图称为第一层书记流程图。从一个加工画出一张数据流程图的过程就是对加工的分解。
确定加工的方法:在数据流的组成或值发生变化的地方应该画出一个加工,这个加工的功能就是实现这一变化,也可以根据系统的功能决定加工。
确定数据流的方法:用户把若干数据当作一个单位来处理(这些数据一起到达、一起处理)时,可以把这些数据看成一个数据流。
关于数据存储:对于一些以后某个时间要使用的数据,可以组织成为一个数据存储来表示。
3、画加工的内部
把每个加工看作一个小系统,把加工的输入输出数据流看成小系统的输入输出流。于是可以象画0层图一样画出每个小系统的加工的DFD图。
4、画子加工的分解图
对第三步分解出来的DFD图中的每个加工,重复第三步的分解过程,直到图中尚未分解的加工都是足够简单的(即不可再分解)。至此,得到了一套分层数据流程图。
5、对数据流程图和加工编号
对于一个软件系统,其数据流程图可能有许多层,每一层又有许多张图。为了区分不同的加工和不同的DFD子图,应该对每张图进行编号,以便于管理。
●顶层图只有一张,图中的加工也只有一个,所以不必为其编号。
●0层图只有一张,图中的加工号分别是0.1、0.2、…,或者1,
2 。
●子图就是父图中被分解的加工号。
●子图中的加工号是由图号、圆点和序号组成,如:1.12,1.3 等
等。
三、应该注意的问题:
1、命名。应适当的为数据流、加工、数据存储以及外部实体命名,名字应该反
映该成分的实际含义,避免使用空洞的名字。
2、画数据流程图,不是画控制流。数据流反映系统“做什么”,不反映“如何
做”,因此箭头上的数据流名称只能是名词或名词短语,整个图中不反映加工的执行顺序。
3、一般不画物质流。数据流反映能用计算机处理的数据,并不是实物,因此对
目标系统的数据流程图一般不要画物质流。
4、一个加工的输出数据流,不应与输入数据流同名,即使他们的组成完全相同。
5、允许一个加工有多条数据流流向另一个加工,也允许一个加工有两条相同的
输出数据流流向不同的加工。
6、编号。如果一张数据流程图中的某个加工分解成另一张数据流程图时,则上
层图为父图,直接下层图为子图。子图及其所有的加工都应编号。
7、保持父图与子图的平衡。也就是说,父图中的某加工的输入输出流必须与他
的子图的输入输出数据流在数量上和名字上相同。值得注意的是,如果父图中的一个输入(输出)数据流对应于子图中的几个输入(输出)数据流,而子图中组成这些数据流的数据项的全体正好是父图中的这一个数据流,那么他们仍然算是平衡的。
8、在自顶向下的分解过程中,若一个数据存储首次出现时,只与一个加工有关
系,那么这个数据存储应作为这个加工的内部文件而不必画出。
9、保持数据守恒,也就是,一个加工的所有输出数据流中的数据必须能从该加
工的输出流中直接获得,或者通过该加工能产生的数据。
10、每个加工必须既有输入数据流,又有输出数据流。
11、在整套数据流程图中,每个数据存储必须既有读的数据流,又有写的数据流。
但是在某张子图中,可能只有读没有写,或者只有写没有读。
12、提高数据流程图的易懂性。注意合理分解,要把一个加工分解成几个功能相
对独立的子加工,这样可以减少加工之间输入、输出数据流的数目,增加数据流程图的可理解性。