软件工程——第5章总体设计知识点整理

news2025/1/11 2:40:36

本专栏是博主个人笔记,主要目的是利用碎片化的时间来记忆软工知识点,特此声明!

 

文章目录

1.总体设计的基本目的?

2.总体设计的任务?

3.总体设计过程由哪两个阶段组成?

4.总体设计的步骤?

5.书写文档记录总体设计的结果,文档的内容有哪些?

6.面向数据流的设计方法是什么?

7.总体设计遵循哪些原理?

8.什么是模块化?

9.模块化的好处?

10.什么是抽象?与软件工程过程有什么关系?

11.什么是逐步求精?

12.什么是模块独立?

13.为什么模块的独立性很重要?

14.什么是耦合?

15.什么是内聚?

16.开发软件对耦合与内聚追求的准则是什么?

17.耦合程度由低到高排序?并分别举例

18.内聚程度由高到低排序?并分别举例?

19.启发式规则有哪些?

20.模块的作用域和控制域分别是什么?

21.深度、宽度、扇入、扇出分别是什么?

22.层次图与层次方框图中连线所代表的含义有什么区别?

23.层次图适用于哪种设计软件的过程中使用?

24.结构图中符号含义?

25.层次图和结构图能表示模块间的调用次序吗?

26.面向数据流的设计方法目标是什么?信息流包括什么?

27.制定测试计划和设计测试用例一样吗?为什么

28.总体设计的必要性?

章末小结


1.总体设计的基本目的?

总体设计又称为概要设计初步设计,主要回答“概括地说,系统应该如何实现”这个问题

2.总体设计的任务?

  1. 通过这个阶段的工作,划分出组成系统的物理元素
  2. 设计软件的结构,确定系统中每个程序是由哪些模块组成的,以及模块之间的关系

3.总体设计过程由哪两个阶段组成?

系统设计阶段、结构设计阶段

4.总体设计的步骤?

  1. 设想供选择的方案
  2. 选取合理的方案
  3. 推荐最佳方案
  4. 功能分解
  5. 设计软件结构
  6. 设计数据库
  7. 制定测试计划
  8. 书写文档
  9. 复查和审查

5.书写文档记录总体设计的结果,文档的内容有哪些?

  1. 系统说明
  2. 用户手册
  3. 测试计划
  4. 详细的实现计划
  5. 数据库设计结果

6.面向数据流的设计方法是什么?

        需求分析阶段得到的数据流图是总体设计的极好出发点,如果数据流图已经细化到适当的层次,则可以直接从数据流图映射出软件结构,这就是面向数据流的设计方法。

7.总体设计遵循哪些原理?

  1. 模块化
  2. 抽象
  3. 逐步求精
  4. 信息隐藏和局部化
  5. 模块独立

8.什么是模块化?

        模块化就是将程序划分成独立命名且可独立访问的模块,每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。

9.模块化的好处?

  1. 采用模块化原理可以使软件结构更加清晰,不仅容易设计也容易阅读和理解
  2. 使软件容易测试与调试
  3. 有助于提高软件的可靠性
  4. 有助于提高软件的可修改性
  5. 有助于开发工程的组织管理

10.什么是抽象?与软件工程过程有什么关系?

抽象是指抽出事物的本质特性暂时不考虑他们的细节

软件工程过程的每一步都是对软件解法的抽象层次的一次精化

11.什么是逐步求精?

        逐步求精是指“为了能够集中精力解决主要问题而尽量推迟对问题细节的考虑”,它是人类解决复杂问题时采用的基本方法,也是许多软件工程技术的基础。求精实际上是细化过程,抽象与求精是一对互补的概念。

【注】可以把逐步求解看作是一项把一个时期内必须解决的种种问题按优先级排序的技术

12.什么是模块独立?

模块独立的概念是模块化、抽象、信息隐藏和局部化概念的直接结果

13.为什么模块的独立性很重要?

  1. 有效的模块化软件比较容易开发出来
  2. 独立的模块比较容易测试和维护

 

14.什么是耦合?

        耦合是衡量不同模块彼此间互相依赖的紧密程度。耦合的强弱取决于模块间接口的复杂程度,进入或访问一个模块的点,以及通过接口的数据。

15.什么是内聚?

内聚是衡量一个模块内部各个元素彼此结合的紧密程度

16.开发软件对耦合与内聚追求的准则是什么?

开发软件追求“低耦合、高内聚”的准则,实践表明内聚更重要

17.耦合程度由低到高排序?并分别举例

  1. 数据耦合:两个模块间通过参数交换信息,而且交换的信息仅仅是数据。比如:两个模块,A模块的运算结果作为参数传入B模块中参与计算
  2. 控制耦合:传递信息中有控制信息,控制耦合把模块适当分解可以用数据耦合来代替。比如:空调遥控器模块和空调外机模块之间的耦合
  3. 特征耦合:把整个数据结构作为参数进行传递,而被调用模块只用其中一部分元素。比如:一个系统需要身份证信息,另一个只需要姓名信息,但把整个用户信息传入就会出现特征耦合
  4. 公共环境耦合:两个或多个模块通过一个公共数据环境相互作用。比如:多个模块共同使用一个全局数组,不同模块可以读、写该数组
  5. 内容耦合:指如果一个模块与另一个模块的内部属性有关,不经过调用而直接使用另一个模块的程序代码或者内部数据就叫做内容耦合。要坚决避免,比如GOTO语句等。

【注1】无连接耦合的耦合程度最低,但是几乎不可能实现

【注2】设计原则:尽量使用数据耦合,少用控制耦合和特征耦合,限制公告环境耦合的范围,完全不用内容耦合

18.内聚程度由高到低排序?并分别举例?

  1. 功能内聚:模块内所有处理元素属于一个整体,完成单一的功能。比如:一个模块中所有的操作都是为了计算出一个人的年龄
  2. 顺序内聚:模块内处理元素和同一个功能密切相关,且处理必须顺序执行。比如:计算成绩平均分,先要输入全部的成绩,计算总分之后再做除法计算平均分。计算总分的输出作为计算平均分的输入,有必须的数据传递,限制了先后关系。
  3. 通信内聚:模块中所有元素都使用同一个输入数据和(或)产生同一个输出数据。比如:有一个子程序负责将输入的信息处理生产报告,同时利用输入数据更新已有的数据,两个操作使用同一个数据源。
  4. 过程内聚:模块内的处理元素相关,且必须以特定次序执行。比如:计算各班同学的平均成绩,要求以先后顺序输出123班的成绩。
  5. 时间内聚:一个模块内包含的任务必须在同一段时间内执行。比如:将多个变量的初始化放在同一个模块中实现。
  6. 逻辑内聚:一个模块完成的任务在逻辑上属于相同或相似的一类。比如:一个模块产生各种类型的输出,打印数字,打印姓名,打印数组等等,他们的功能都是打印输出信息,功能相同。
  7. 偶然内聚:一个模块完成一组任务,完成任务彼此之间即使有关系,关系也很松散。比如:A模块中有n条语句,但是这些语句彼此之间没有关系。

19.启发式规则有哪些?

  1. 改进软件结构,提高模块独立性
  2. 模块规模应该适中
  3. 深度、宽度、扇入、扇出都应该适当
  4. 模块作用域应该在控制域之内
  5. 力争降低模块接口的复杂程度
  6. 设计单入口单出口的模块
  7. 模块功能应该可以预测

20.模块的作用域和控制域分别是什么?

作用域:受该模块内一个判定影响的所有模块的集合

控制域:这个模块本身以及所有直接或从属于它的模块的集合

 【注】以上图为例,A模块的控制域就是A、B、C、D、E、F

21.深度、宽度、扇入、扇出分别是什么?

  1. 深度:表示软件结构中控制的层数,它往往能粗略地表明一个系统的大小和复杂程度
  2. 宽度:表示软件结构内同一个层次上的模块总数的最大值。一般来说,宽度越大系统越复杂。对宽度影响最大的因素是模块的扇出
  3. 扇出:表示一个模块直接控制(调用)的模块数目。好的系统平均扇出是3~4个
  4. 扇入:表示有多少个上级模块调用它,扇入多表面该模块被调用的次数多,比较好

22.层次图与层次方框图中连线所代表的含义有什么区别?

层次图的连线表示调用关系,而层次方框图中连线表示组成关系

 

 【注】第2张图是层次方框图,它是以实体的角度出发进行分析,而层次图是以功能的角度

23.层次图适用于哪种设计软件的过程中使用?

自顶向下

24.结构图中符号含义?

结构图是进行软件设计的另一个有力工具

一个方框代表一个模块,之间的箭头表示模块调用关系,带注释的箭头代表模块调用过程中来回传递的消息

 

25.层次图和结构图能表示模块间的调用次序吗?

        层次图和结构图不能严格表示模块间的调用次序,他们并不指明什么时候调用下层模块,而只是表明一个模块调用哪些模块

26.面向数据流的设计方法目标是什么?信息流包括什么?

面向数据流的设计方法目标是给出设计软件结构的一个系统化的途径

信息流包括变换流与事物流

 

27.制定测试计划和设计测试用例一样吗?为什么

        二者不一样,因为在总体设计阶段制定测试计划,但此时还没有具体的代码实现,所以无法具体的写出每条测试用例。

28.总体设计的必要性?

        可以站在全局高度上,花较少的成本,从比较抽象的层次上分析对比多种可能的系统实现方案和软件结构,从中选出最佳方案和最合理的软件结构,从而用较低成本开发出较高质量的软件系统。

章末小结

        总体设计阶段的基本目的是用比较抽象概括的方式确定系统如何完成预定的任务,也就是说:应该确定系统的物理配置方案,并且进而确定组成系统的每个程序的结构。因此,总体设计阶段主要由两个小阶段组成。首先需要进行系统设计,从数据流图出发设想完成系统功能的若干种合理的物理方案,分析员应该仔细分析比较这些方案,并且和用户共同选定一个最佳方案。然后进行软件结构设计,确定软件由哪些模块组成以及这些模块之间的动态调用关系。层次图和结构图是描绘软件结构的常用工具。
        在进行软件结构设计时应该遵循的最主要的原理是模块独立原理,也就是说,软件应该由一组完成相对独立的子功能的模块组成这此模块彼此之间的接口关系应该尽量简单。
        抽象和求精是一对互补的概念,也是人类解决复杂问题时最常用、最有效的方法。在进行软件结构设计时一种有效的方法就是,由抽象到县体地构造出软件的层次结构。

        软件工程师在开发软件的长期实践中积累了丰富的经验,总结这些经验得出一些很有参考价值的启发式规则,它们往往能对如何改进软件设计给出宝贵的提示。在软件开发过程中既要充分重视和利用这些启发式规则,又要从实际情况出发避免生搬硬套

        自顶向下逐步求精是进行软件结构设计的常用途径;但是,如果已经有了详细的数据流图,也可以使用面向数据流的设计方法,用形式化的方法由数据流图映射出软件结构。应该记住这样映射出来的只是软件的初步结构 ,还必须根据设计原理并且参考启发式规则,认真分析和改进软件的初步结构以得到质量更高的模块和更合理的软件结构。
        在进行详细的过程设计和编写程序之前,首先进行结构设计,其好处正在于可以在软件开发的早期站在全局高度对软件结构进行优化。在这个时期进行优化付出的代价不高,却可以使软件质量得到重大改进

 反反复复,扎扎实实;念念不忘,必有回响!

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

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

相关文章

【Linux从入门到精通】进程地址空间(虚拟地址 vs 物理地址)

本篇文章会围绕三个问题(什么是地址空间?地址空间是如何设计的?为什么要有地址空间?)进行展开讲述。其中主要是了解虚拟地址和物理地址的区别。希望本篇文章会对你有所帮助。 文章目录 一、什么是地址空间?…

《机器学习公式推导与代码实现》chapter6-k近邻算法

《机器学习公式推导与代码实现》学习笔记,记录一下自己的学习过程,详细的内容请大家购买作者的书籍查阅。 k近邻算法 k近邻(k-nearest neighbor, k-NN)算法是一种经典的分类算法。k近邻算法根据新的输入实例的k个最近邻实例的类别来决定其分类。所以k近…

rust abc(1): 最小环境搭建

文章目录 1. 目的2. 命令集合3. 安装或更新 rust3.1 命令3.2 运行结果 4. 包管理工具 Cargo5. 创建 Rust 的 Hello World 程序: 单个文件6. 创建 Rust 的 Hello World 工程: 基于 Cargo6.1 cargo new 创建工程6.2 cargo run6.3 完整输出6.4 解释 7. IDE/编辑器8. Re…

Jetson安装Anaconda(miniforge3)

1 miniforge3 miniforge集成了Anaconda的核心工具:conda。conda是一个包和环境管理工具。因此, miniforge里面的conda和Anaconda里面的conda完全一样;你能用Anaconda做的安装、升级、删除包等功能,miniforge都能做;你…

angular实现自定义模块路由懒加载;配置自定义模块路由及子路由

图片中绿色表示新建的文件;黄色表示被更改的文件; 1、创建一个新的项目 ng new angularlazyload2、创建一个用户模块,并配置路由 ng g module module/user --routing如图: 3 、在module/模块下创建user组件 ng g component module/user如图: 4、实现路由懒加载 依次…

java00——类和对象

在Java中一切皆对象 什么是对象? 一个人、一只猫、一条狗…这些就是一个对象; 每个对象都有属性和行为。 什么是类? 类即同类别,例如不论男人、女人、黑人、白人…,都是人类,即同一类事务的统称。 类的…

HTB-Sandworm

HTB-Sandworm 立足altas -> silentobserversilentobserver -> 完整的atalsatlas -> rootexploit 扫描最常用的1000个端口。 80会重定向到443。 去看看443有什么吧。 目录扫描可能不会起作用。在concat上面找到了一个有趣的东西。 “如果不知道怎么PGP&#xff1…

Axure教程—折叠面板

本文介绍利用Axure中的动态面板制作折叠面板 一、效果 预览地址:https://3k8az1.axshare.com 二、功能 1、点击标题展开面板内容 2、点击标题折叠面板 三、制作 从默认元件库拖入一个动态面板,设置两个状态,一个状态面板标题,一…

【MySQL】不允许你还不了解创建计算字段

🎬 博客主页:博主链接 🎥 本文由 M malloc 原创,首发于 CSDN🙉 🎄 学习专栏推荐:LeetCode刷题集! 🏅 欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指…

【开源与项目实战:开源实战】82 | 开源实战三(中):剖析Google Guava中用到的几种设计模式

上一节课,我们通过 Google Guava 这样一个优秀的开源类库,讲解了如何在业务开发中,发现跟业务无关、可以复用的通用功能模块,并将它们从业务代码中抽离出来,设计开发成独立的类库、框架或功能组件。 今天,…

【后端】使用TS编写任务管理系统----Express

文章目录 常见的后端框架安装并且声明文件库项目基本配置编写任务管理后端API添加任务查看任务设置任务完成状态删除任务 总结 node -v v16.13.0https://github.com/dL-hx/server-side 常见的后端框架 expresskoa… 安装并且声明文件库 $ npm i express $ npm i types/exp…

前端vue入门(纯代码)14

内容创作不易,各位帅哥美女,求个小小的赞!!! 【15.给todoList案例添加编辑按钮】 本篇内容在TodoList案例的基础上添加个编辑按钮,要求: (1)点击编辑按钮后&#xff0c…

轻松学会研华屏幕下载和上传

🔥一个人走得远了,就会忘记自己为了什么而出发,希望你可以不忘初心,不要随波逐流,一直走下去🎶 🦋 欢迎关注🖱点赞👍收藏🌟留言🐾 ✅ 如果觉得博主…

HashMap和HashSet的知识点总结

前言 在之前我们介绍过TreeMap和TreeSet: TreeMapTreeSet 知识点梳理总结_Crystal_bit的博客-CSDN博客 也知道Key-Value和Key模型,但是我们可能还对Hash不太了解,这里我们对Hash了解之后再对HashMap和HashSet的基本使用了解一下。 目录 1…

LabVIEW 图像处理功能

设置成像系统并采集图像后,您可以分析和处理图像,以提取有关被检测对象的有价值信息。 内容 图像分析图像处理斑点分析机器视觉 图像分析 影像分析结合了基于影像像素的灰度强度计算统计数据和测量的技术。您可以使用影像分析功能来确定影像质量是否足以…

scratch lenet(10): C语言计算log

scratch lenet(10): C语言计算log 文章目录 scratch lenet(10): C语言计算log1. 目的2. 原理: x m ∗ 2 p x m * 2^p xm∗2p3. 公式展开3.1 公式分解3.2 获取 m m m3.3 获取 p p p3.4 Remez 算法Remez 算法用于 sin(x) 的快速计算Remez 算法用于 exp 的近似Remez 用于自然…

【MySQL数据库】存储过程

目录 一、存储过程1.1概述1.2优点 二、存储过程实战2.1创建存储过程2.2存储过程的参数2.3条件语句 if-then-else end if2.4循环语句while end while 一、存储过程 1.1概述 存储过程是一组为了完成特定功能的SQL语句集合。存储过程在使用过程中是将常用或者复杂的工作预先使…

CSS基础学习--25 border(边框)进阶

一、边框常见属性 border-radiusbox-shadowborder-image 属性说明CSSborder-image设置所有边框图像的速记属性。3border-radius一个用于设置所有四个边框- *-半径属性的速记属性3box-shadow附加一个或多个下拉框的阴影3 二、border-radius 圆角 在 CSS2 中添加圆角棘手。我…

网络协议TCP/IP 协议学习笔记一

T C P / I P通常被认 为是一个四层协议系统,每一层负责不同的功能: 1) 链路层,有时也称作数据链路层或网络接口层, 通常包括操作系统中的设备驱动程序和计算机 中对应的网络接口卡。它们一起处理与电缆(或其他任何传输…