软件设计师教程第6章结构化开发方法

2023-10-18 22:59

本文主要是介绍软件设计师教程第6章结构化开发方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

结构化方法又结构化分析、结构化设计、结构化程序设计构成。它是一种面向数据流的开发方法。

结构化分析是根据分解与抽象的原则,按照系统中数据处理的流程,用数据流图来建立系统的功能模型,从而完成需求分析工作。结构化设计是根据模块独立性准则、软件结构优化准则将数据流图转化为软件的体系结构,用软件结构图来建立系统的物理模型,实现系统概要设计。结构化程序设计使用3中基本控制结构构造程序,任何程序都可以由顺序、选择和重读3种基本控制结构构造。

结构化方法的指导思想是自顶向下、逐层分解,它的基本原则是功能的分解与抽象。它是软件工程中最早出现的开发方法,特别适合于数据处理的问题,但不适合解决大规模的。特别复杂的项目,难以适应需求的变化。

6.1系统分析与设计概述

6.1.1系统分析概述

系统分析是一种面向问题求解技术,它将一个系统分解成各个组成部分,目的是研究各个部分如何工作、交互,以实现其系统的目标。强调业务方面的问题,而非技术或实现方面。

1.系统分析的目的和任务

进过一系列分析,提交系统方案说明书

2.系统分析的主要步骤

(1)认识和理解当前现实环境,获得当前系统的“物理模型”

(2)从当前系统的物理模型抽象出当前系统的“逻辑模型”

(3)从当前系统的“逻辑模型”进行分析和优化,建立目标系统的“逻辑模型”

(4)从目标系统的逻辑模型具体化,建立目标系统的物理模型

6.1.2系统设计的基本原理

1.抽象

2.模块化

3.信息隐蔽

4.模块独立

模块独立是指每个模块完成一个相对独立的特定子功能,并且与其他模块之间的联系简单。衡量模块独立成都的标准有两个:

耦合性和内聚性。

1)耦合

一般有7中类型,从低到高依次为:

无直接耦合。指两个模块没有直接的关系,分别从属于不同模块的控制与调用,它们之间不传递任何信息,

数据耦合。指连个模块间有调用关系,传递是简单的值传递

标记耦合。指两个模块之间传递的是数据结构

控制耦合 。指一个模块调用另一个模块时,传递的是控制变量,被调用模块通过控制该控制变量的值选择的执行模块内的某一功能。因此,被调用模块应该具有多个功能,哪个功能起作用收到模块控制

外部耦合。模块之间通过软件之外的环境联结(比如特定设备,格式,通讯协议)时称为外部耦合

公共耦合。指通过一个公共数据环境相互作用的那些模块间的耦合

内容耦合。当一个模块直接使用另一个模块的内部数据,或通过非正常入口转入另一个模块的内部时,这种模块之间的耦合称为内容耦合。

2)内聚

内聚的分为7种类型从低到高

偶然内聚。指一个模块内的各个元素之间没有任何联系。

逻辑内聚。值模块内执行若干个逻辑相似的功能,通过参数确定执行该模块完成哪一个功能。

时间内聚。指一个模块同时执行的动作组合在一起形成的模块

过程内聚。值一个模块需要完成多个任务,这些任务必须按指定的过程执行

通信内聚。指模块内的所有处理元素都在同一个数据结构上操作,或者各处理使用相同的输入数据或者产生相同的输出数据。

顺序内聚。指一个模块中的各个元素都密切相关于同一功能且必须顺序执行,前一功能元素的输出就是下功能元素的输入

功能内聚。这是最强的内聚,指模块内的所有元素共同完成一个功能缺一不可。

6.1.3系统总体结构设计

1.系统结构设计原则

2.子系统划分

3.系统模块结构设计

1)模块的概念

模块是组成系统的基本单位,它的特点是可以组合、分解和更换。模块分为物理模块和逻辑模块

一个模块应具备4个要素

(1)输入与输出

(2)处理功能

(3)内部数据

(4)程序代码

前两个是模块外部属性,后两个是内部属性

2)模块结构图

模块结构图主要关心的是模块的外部属性,即上下级模块、同级模块之间的数据传递和调用关系,并不关心模块的内部。

模块结构图是结构化设局中描述系统结构的图形工具。

模块结构图由模块、调用、数据、控制信息和转接符号5种基本符号组成。

4.数据存储设计

参照第9章

6.1.4系统文档

信息系统的文档是系统建立过程中的“痕迹”,是系统维护人员的指南,是开发人员与用户交流的工具。

6.2结构化分析方法

结构化分析与设计方法是一种面向数据流的传统软件开发方法,它以数据流为中心构建软件的分析模型和设计模型。

6.2.1结构化分析方法概述

抽象和分解是处理任何复杂问题的两个基本手段。

结构化分析的结果由以下几部分组成:一套分层的数据流图、一本数据词典、一组小说明(也称加工逻辑说明)、补充材料。

6.2.2数据流图

数据流图也称数据流程图(Data Flow Diafram ,DFD),它是一种用户理解、分析系统数据流程的图形工具。是系统逻辑模型的重要组成部分。

1.数据流图的基本图形元素

数据流图的基本图形元素包括数据流(data flow)、加工(process)、数据存储(data store)和外部实体(external agent),其中,数据流、加工和数据存储用于构建软件系统内部的数据处理模型:外部实体表示存在系统之外的对象。

2.数据流图的扩充符号

1)星号(*)

与关系

2)加号(+)

或关系

3)异或(\bigoplus

3.数据流图的层次结构

分层数据流图的顶层图只有一张图,其中只有一个加工,代表整个软件系统。

4.分层数据流图的画法

5.分层数据流图的审查

6.2.3数据字典(DD)

数据流图描述了系统的分解,但没有对图中各成分进行说明,数据字典就是为数据流图中的每个数据流、文件、加工以及组成数据流或文件的数据项做出说明。其中对加工的描述称为“小说明”,也称为加工逻辑说明。

1、数据字典的内容

2.数据词典的管理

3.加工逻辑的描述

6.3结构化设计方法

结构化设计(structure design)方法是一种面向数据流的设计方法。

6.3.1结构化设计的步骤

1,建立初始结构图

2.对结构图的改进

3.书写设计文档

4.设计评审

6.3.2数据流图到软件体系结构的映射

1.信息流的类型

2.变换分析

6.4WebApp分析与设计

6.5用户界面设计

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

这篇关于软件设计师教程第6章结构化开发方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/235650

相关文章

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

Centos环境下Tomcat虚拟主机配置详细教程

《Centos环境下Tomcat虚拟主机配置详细教程》这篇文章主要讲的是在CentOS系统上,如何一步步配置Tomcat的虚拟主机,内容很简单,从目录准备到配置文件修改,再到重启和测试,手把手带你搞定... 目录1. 准备虚拟主机的目录和内容创建目录添加测试文件2. 修改 Tomcat 的 server.X

Python中的输入输出与注释教程

《Python中的输入输出与注释教程》:本文主要介绍Python中的输入输出与注释教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、print 输出功能1. 基础用法2. 多参数输出3. 格式化输出4. 换行控制二、input 输入功能1. 基础用法2. 类

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

Spring Boot拦截器Interceptor与过滤器Filter详细教程(示例详解)

《SpringBoot拦截器Interceptor与过滤器Filter详细教程(示例详解)》本文详细介绍了SpringBoot中的拦截器(Interceptor)和过滤器(Filter),包括它们的... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)详细教程1. 概述1

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my