软件工程--软件建模--结构化方法通俗语言总结(暴肝超详解)(包含数据流图、数据字典、ER图、结构化设计和优化......)

news2025/1/13 11:59:01

目录

结构化分析

数据流图DFD

定义数据字典

实体关系图(E-R图)

结构化设计

变换映射

事务映射

优化结构设计

实例分析

详细设计(过程设计)


结构化方法是一种系统化开发软件的方法,该方法基于模块化的思想,包括结构化分析、结构化设计和结构化编程,本文重点介绍结构化分析和结构化设计

本文参考教材:沈备军老师的《软件工程原理》大多图片来源其中

结构化分析

结构化分析是一种以组织和规范化系统设计的方式。结构化方法有助于将复杂的软件系统分解为更简单、易于理解的部分,从而方便开发和维护

组成结构如下所示,核心的数据字典(DD),从DD出发可构成三种图

DFD(数据流图) 

数据流图是一种图形工具,用于表示系统中数据的流动以及各个处理数据的模块。它是结构化分析方法的一部分,强调数据的流动和数据处理的过程。

ERD(实体关系图)

ER图是一种用于描述系统中的实体以及它们之间关系的图形工具。实体表示系统中可以区分的对象,而关系表示这些对象之间的联系。

STD(状态图)

状态变迁图是一种描述系统中对象状态及其状态之间转换关系的图形工具。它适用于建模有限状态机(Finite State Machine)。

数据流图DFD

数据流图(DFD)使用4种基本图形符号进行建模:

圆边矩形或者圆形代表加工;

箭头代表数据的流向,数据名称总是标在箭头的边上;

方框表示数据的源(发送数据)和宿(接收数据),即与系统打交道的人或外界系统

双杠(或单杠)表示数据存储(具体实现有文件系统、数据库系统,存储介质:磁盘、磁带或其它存储介质)

分层数据流图:自顶向下逐层分解+按照层次结构绘制+每张图中的加工个数大致控制在“7+-2”范围内

顶层图:描述了软件系统与外界之间的数据流,只有一张图,一个加工(代表整个软件系统)

0层图:顶层图中加工经过分解后的图,也只有一张

中间层:除了顶层、0层、底层的其它图

底层图:处于最底层的图,底层图中所有的加工不能再分解

父图和子图:如果某图A中某一个加工分解成一张子图B,则称A是B的父图,B是A的子图,若父图中有n个加工,则它可以有0-n张子图

加工编号:顶层图只有1个加工,不必编号,0层图的加工编号分别为1、2、3...子图号就是父图中被分解的加工号,如果父图中加工号为x的加工分解为某一子图,则该子图中加工编号分别为x.1,x.2,x.3......

画分层数据流图就是先构建顶层DFD,然后对顶层DFD图细化,构建0层DFD,接着继续细化

下面以考务处理系统为例,来展示上面的概念:

这是顶层DFD,可以发现只有一个加工,加工的名称就是系统的名称

分解成0层图如下:

可以看到这样以来,就出现了两个加工,下面对0层图中加工序列为2的加工进行分解,分解成1层图(这知识其中一个1层图,上面已经说了如果有n个加工是可以有0-n个子图的)

通过上面可以发现几个规律:

1.任何一张DFD的子图边界上的输入/输出数据流必须与其父图中对应加工的输入/输出数据流保持一致

比如上面顶层图加工输出流6个,输入流3个,分解成0图,边界上的输入/输出流也是这个数量

2.每个加工至少有一个输入数据流和一个输出数据流

3.在整套分层数据流图中,每个数据存储应该至少有一个加工对其进行读操作,另一个加工对其进行写操作,但对于一张DFD来说,可以只写或只读不写

定义数据字典

数据字典是描述数据的信息的集合,是对 系统中使用的所有数据元素或者数据流图中包含的所有元素 的定义的集合。是为了描述在结构化分析过程中定义对象的内容时,使用的一种半形式化的工具。

数据字典的信息包括:

数据的名称、别名、简要简述,数据流组成、数据流来源、数据流去向、数据类型、取值范围、峰值等信息

其中对于“数据流组成”这个板块可以用下面的符号表述:

还是以上面考务处理系统为例,定义“成绩清单”的字典条目如下:

实体关系图(E-R图)

实体-关系图(Entity-Relationship Diagram,简称E-R图)是一种用来表示实体及其之间关系的图形化工具,包含以下元素:

矩形框:表示实体,在框中记入实体名。

菱形框:表示联系,在框中记入联系名。

椭圆形框:表示实体或联系的属性,将属性名记入框中。对于主属性名,则在其名称下划一下划线。

连线:实体与属性之间;实体与联系之间;联系与属性之间用直线相连,并在直线上标注联系的类型。(对于一对一联系,要在两个实体连线方向各写1; 对于一对多联系,要在一的一方写1,多的一方写N;对于多对多关系,则要在两个实体连线方向各写N,M。)

结构化设计

结构化设计的任务就是把用DFD表示的分析模型转换为以结构图(Structure Chart,SC)表示的设计模型。

结构图描述一个软件系统由哪些模块组成,以及模块之间的调用关系,结构图的基本成分有:模块、调用和数据

模块是指具有一定功能的可以用模块名调用的一组程序语句,包括函数和子程序。

调用(call):用从一个模块指向另一个模块的箭头来表示,其含义是前者调用了后者
为了方便,有时常用直线替代箭头,此时,表示位于上方的模块调用位于下方的模块
数据(data):模块调用时需传递的参数可通过在调用箭头旁附加一个小箭头和数据名来表示

结构图的三种调用表示:

DFD分为变换型结构和事务型结构两种

变换流

特征:数据流图可明显地分成三部分
输入:信息沿着输入路径进入系统,并将输入信息的外部形式经过编辑、格式转换、合法性检查、预处理等辅助性加工后变成内部形式
变换:内部形式的信息由变换中心进行处理
输出:然后沿着输出路径经过格式转换、组成物理块、缓冲处理等辅助性加工后变成输出信息送到系统外

事物流

特征:数据流沿着输入路径到达一个事务中心,事务中心
根据输入数据的类型在若干条动作路径中选择一条来执行  事务中心的任务是:接收输入数据(即事务);分析每个事务
的类型;根据事务类型选择执行一条动作路径

针对上述两种类型DFD,从DFD映射到SC也提出了两种类型,分别叫做变换映射和事物映射

变换映射

一般步骤如下:

划定输入流和输出流的边界,确定变换中心
进行第一级分解:将DFD映射成变换型的程序结构
进行第二级分解:将DFD中的加工映射成结构图中的一个适当的模块
标注输入输出信息:根据DFD,在初始结构图上标注模块之间传递的输入信息和输出信息

先举一个抽象的例子:

下面针对上述考务处理系统其中一个1层DFD图为例,来演示结构化设计的过程

这是第一步,任务是区分输入、输出和变换中心三个部分

下面要进行第一级分解:

在分解之前,我们可以先看一下对于一个任意的SC的框架,通常包含什么

对于一个任意的SC的框架通常包括最上面的两层模块——顶层和0层,任何系统的顶层都只含一个用于控制的主模块,它的下一层一般包括输入、输出、变换(控制)三个模块,分别对应SC的三个分支

因此对于上述的DFD变换映射的第二步(第一级分解)可以直接写成:

第三步:完成第二级分解,细化SC的各个分支。
对上步的结果继续进行由顶向下的分解,直至画出每个分支所需要的全部模块

可以好好对比下面两个图以加深理解

注意:从“加工”和“数据存储”中传递的数据在SC中有不同的体现,“数据存储”中传递的内容不用体现在SC上,比如“考生名册”传递给2.3和2.4的数据就没有体现

事务映射

与变换映射相似,事务映射也可以分为3个步骤

1.在DFD上确定事务中心接收部分(包括输入路径)和发送部分(包括全部动作)

2.画出SC框架,把DFD的3个部分分别映射为事务控制模块、接受模块和动作发送模块,一般的SC框架如下所示:


3.分解和细化接受分支和发送分支,完成初始的SC,下面举一个抽象的例子:

优化结构设计

扇入和扇出:

扇入是指直接调用该模块的上级模块的个数。扇入大表示模块的复用程序高

扇出:是指该模块直接调用的下级模块的个数。扇出大表示模块的复杂度高,需要控制和协调过多的下级模块;但扇出过小(例如总是1)也不好。扇出过大一般是因为缺乏中间层次,应该适当增加中间层次的模块。扇出太小时可以把下级模块进一步分解成若干个子功能模块,或者合并到它的上级模块中去

比如左图的答案就是3

扇出过大的情况:

设计良好的软件通常具有瓮形结构,两头小,中间大,这类软件在下部收拢,表明它在底层模块中使用了较多高扇入的共享模块,比如下面这个图:

优化的另一个方法是:模块的作用域应限制在该模块的控制域范围内

先来介绍什么是作用域和控制域

一个模块的控制域是指该模块自身及其下级模块(即可供它调用的模块),比如说顶层模块的控制域是下面的全部模块(包含顶层模块自身)

一个模块的作用域是受这个模块中的判定所影响的模块,这个要看具体的情况,位置是不确定的,下面会举具体例子

上面是四种设计,其中带阴影的模块受带菱形的模块的影响,那么这四种设计哪一种最优呢?

先看a图,A受B2影响,但是A不在B2的控制域范围内(B2没有调用任何模块),所以这个设计是不好的

再看b图,A和B2受顶层模块Top的影响,也就是说Top的作用域确实在其控制域范围内,但存在一个问题:从决策控制模块到被控模块之间相差的层次太多

因此c、d图相对b要更好,其中d图是这四个设计中最优的选择

实例分析

还是以上面已经划过的SC为例:

第一步优化:减少耦合度

1.将“输入成绩清单”、“检查成绩清单”、“打印成绩单出错信息”合并成“输入并检查成绩清单”
2.将“输入合格标准”与“审定合格者”合并,仍取名“审定合格者”,但它包含读入合格标准功能
3.将“产生考生通知单”与“打印考生通知单”合并成“产生并打印考生通知单”

第二步优化:模块的作用域应限制在该模块的控制域范围内

很容易发现,此时“打印难度分析表”、“打印分类统计表”分别受“分析试题难度”、“分类统计成绩”的影响,所以将“打印难度分析表”、“打印分类统计表”放在“分析试题难度”、“分类统计成绩”的控制域下面

第三步优化:删除多余模块

可以看出,此时“统计成绩输出控制”模块已经没有存在的意义了,删除即可

删除之后,发现“统计成绩输入控制”和“统计成绩处理模块”也没有存在的意义了,因为这两个模块的原来的意义在于为数据选择一个道路分支,但是由于只有把“统计成绩输出控制”删除之后只有一条路可以选择了,所以“统计成绩输入控制”和“统计成绩处理模块”就成了“管道模块”,直接删除即可

详细设计(过程设计)

系统的详细设计就是对SC中的每个模块给出足够详细的过程性描述,常用的结构化详细设计的表达工具包括程序流程图、PAD图、N-S图和伪代码

本文重点对程序流程图做出注解

一个结构化的程序设计的程序流程图必须满足:是一种采用自顶向下逐步求精的设计方法和单入口单出口的控制结构

比如下面就不是结构化的:

通常所说的结构化程序,是按照狭义的结构程序的 定义衡量,符合定义规定的程序,每个代码块只有一个入口 和一个出口,上述这个图中圈起来的代码块(选择结构)中有两个入口,分别从C1过来和从A过来,所以是非结构化

改成结构化可以采用重复编码技术:

再举一个例子:

图示的程序的循环控制结构有两个出口,分别从p出和从q出。显然 不符合狭义的结构程序的定义,因此是非结构化的程序,可以修改为:

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

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

相关文章

vue3项目中使用富文本编辑器

前言 适配 Vue3 的富文本插件不多,我看了很多插件官网,也有很多写的非常棒的,有UI非常优雅让人耳目一新的,也有功能非常全面的。 如: Quill,简单易用,功能全面。editorjs,UI极其优…

【OpenCV实现图像:使用OpenCV生成拼图效果】

文章目录 概要通用配置不考虑间隔代码实现考虑间隔代码实现小结 概要 概要: 拼图效果是一种将图像切割为相邻正方形并重新排列的艺术效果。在生成拼图效果时,可以考虑不同的模式,包括是否考虑间隔和如何处理不能整除的部分。 不考虑间隔&a…

〖大前端 - 基础入门三大核心之JS篇㊶〗- DOM事件传播和事件监听方法addEventListener()

说明:该文属于 大前端全栈架构白宝书专栏,目前阶段免费,如需要项目实战或者是体系化资源,文末名片加V!作者:不渴望力量的哈士奇(哈哥),十余年工作经验, 从事过全栈研发、产品经理等工作&#xf…

华清远见嵌入式学习——网络编程——作业3

目录 作业要求&#xff1a;基于UDP的TFTP文件传输 代码 下载功能效果图​编辑 上传功能效果图 思维导图 模拟面试题和答案&#xff08;定期更新&#xff09; 作业要求&#xff1a;基于UDP的TFTP文件传输 完成文件的上传和下载功能 代码 #include<myhead.h>//实现…

CSS特效016:天窗扬起合上的效果

CSS常用示例100专栏目录 本专栏记录的是经常使用的CSS示例与技巧&#xff0c;主要包含CSS布局&#xff0c;CSS特效&#xff0c;CSS花边信息三部分内容。其中CSS布局主要是列出一些常用的CSS布局信息点&#xff0c;CSS特效主要是一些动画示例&#xff0c;CSS花边是描述了一些CSS…

在PyCharm中正确设置Python项目

大家好&#xff0c;在Mac和Linux都支持Python&#xff0c;但许多开发者发现正确设置Python项目很困难。本文汇总了多平台中运行Python的方法&#xff0c;提高编程的效率&#xff0c;如下所示&#xff1a; 使用命令行运行Python。 在PyCharm&#xff08;免费社区版&#xff09;…

微信小程序蓝牙连接 uniApp蓝牙连接设备

蓝牙列表期待效果 代码 <template><view class"bluetooth-list"><view class"align-items option" style"justify-content: space-between;" v-for"item in bluetoothList" :key"item.deviceId"><vie…

java基础-集合

1、集合 在java中&#xff0c;集合&#xff08;Collection&#xff09;指的是一组数据容器&#xff0c;它可以存储多个对象&#xff0c;并且允许用户通过一些方法来访问与操作这些对象。j 集合的实现原理都基于数据结构和算法&#xff0c;如下&#xff1a; 数据结构&#xff1…

[ 云计算 | AWS 实践 ] 基于 Amazon S3 协议搭建个人云存储服务

本文收录于【#云计算入门与实践 - AWS】专栏中&#xff0c;收录 AWS 入门与实践相关博文。 本文同步于个人公众号&#xff1a;【云计算洞察】 更多关于云计算技术内容敬请关注&#xff1a;CSDN【#云计算入门与实践 - AWS】专栏。 本系列已更新博文&#xff1a; [ 云计算 | …

Redis-Redis缓存高可用集群

1、Redis集群方案比较 哨兵模式 在redis3.0以前的版本要实现集群一般是借助哨兵sentinel工具来监控master节点的状态&#xff0c;如果master节点异常&#xff0c;则会做主从切换&#xff0c;将某一台slave作为master&#xff0c;哨兵的配置略微复杂&#xff0c;并且性能和高可…

深度学习图像修复算法 - opencv python 机器视觉 计算机竞赛

文章目录 0 前言2 什么是图像内容填充修复3 原理分析3.1 第一步&#xff1a;将图像理解为一个概率分布的样本3.2 补全图像 3.3 快速生成假图像3.4 生成对抗网络(Generative Adversarial Net, GAN) 的架构3.5 使用G(z)生成伪图像 4 在Tensorflow上构建DCGANs最后 0 前言 &#…

Kubernetes(k8s)之Pod详解

文章目录 Kubernetes之Pod详解一、Pod介绍pod结构pod定义 二、Pod配置pod基本配置镜像拉取策略启动命令环境变量端口设置资源配额 三、Pod生命周期创建和终止初始化容器钩子函数容器探测重启策略 四、Pod调度定向调度NodeNameNodeSelector 亲和性调度NodeAffinityPodAffinityPo…

【11月比赛合集】48场可报名的数据挖掘大奖赛,任君挑选!

CompHub[1] 实时聚合多平台的数据类(Kaggle、天池…)和OJ类(Leetcode、牛客…&#xff09;比赛。本账号会推送最新的比赛消息&#xff0c;欢迎关注&#xff01; 以下信息仅供参考&#xff0c;以比赛官网为准 目录 Kaggle&#xff08;9场比赛&#xff09;阿里天池&#xff08;…

Visual Studio连接unity编辑器_unity基础开发教程

Visual Studio连接unity编辑器 问题描述解决方法意外情况 问题描述 当我们在unity编辑器中打开C#脚本的时候发现Visual Studio没有连接unity编辑器&#xff0c;在编写代码的时候也没有unity关键字的提醒。 简单来说就是敲代码没有代码提示。 解决方法 这时候需要在unity中进行…

nodejs微信小程序+python+PHP-储能电站运营管理系统的设计与实现-计算机毕业设计推荐

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

MS9708/MS9710/MS9714高速、低功耗数模转换器,可替代ADI的

产品简述 MS9708/MS9710/MS9714 是一个 8-Bit/10-Bit/14-Bit 高速、低功耗 D/A 转换器。当采样速率达到 125MSPS 时&#xff0c; MS9708/MS9710/MS9714 也能提供优越的 AC 和 DC 性能。 MS9708/MS9710/MS9714 的正常工作电压范围为 2.7V 到 5.5V &#xff0c;…

供应链和物流的自动化新时代

今天&#xff0c;当大多数人想到物流自动化时&#xff0c;他们会想到设备。机器人、无人机和自主卡车运输在大家的谈话中占主导地位。全自动化仓库的视频在网上流传&#xff0c;新闻主播们为就业问题绞尽脑汁。这种炒作是不完整的&#xff0c;它错过了供应链和物流公司的机会。…

【机器学习】On the Identifiability of Nonlinear ICA: Sparsity and Beyond

前言 本文是对On the Identifiability of Nonlinear ICA: Sparsity and Beyond (NIPS 2022)中两个结构稀疏假设的总结。原文链接在Reference中。 什么是ICA(Independent component analysis)&#xff1f; 独立成分分析简单来说&#xff0c;就是给定很多的样本X&#xff0c;通…

BLE通用广播包

文章目录 1、蓝牙广播数据格式2、扫描响应数据 1、蓝牙广播数据格式 蓝牙广播包的最大长度是37个字节&#xff0c;其中设备地址占用了6个字节&#xff0c;只有31个字节是可用的。这31个可用的字节又按照一定的格式来组织&#xff0c;被分割为n个AD Structure。如下图所示&…

微机原理_1

一、单项选择题(本大题共15小题,每小题3分,共45分。在每小题给出的四个备选项中,选出一个正确的答案,请将选定的答案填涂在答题纸的相应位置上。) 1,下列8086CPU标志寄存器的标志位中,不属于状态标志位的是(&#xff09; A. OF B. IF C. AF D. PF 8086微处理器可寻址访问的最大…