软件工程实务学习总结( 二 )


软件工程实务学习总结

文章插图
软件设计宣言-Mitch Kapor:“什么是设计?设计是你站在两个世界——技术世界和人类的目标世界——而你尝试将这两个世界结合在一起……” 。
罗马建筑批评家提出的观念:“设计良好的建筑应该展示出坚固、适用和令人赏心悦目” 。
设计阶段:
■从工程管理的角度 , 可以将软件设计分为概要设计阶段和详细设计阶段 。
■从技术的角度 , 传统的结构化方法将软件设计划分为体系结构设计、数据设计、接口设计和过程设计4部分 。
■面向对象方法则将软件设计划分为体系结构设计、类设计/数据设计、接口设计和构件级设计4部分 。
结构化设计和结构化分析的关系:
总体设计过程:
首先寻找实现目标系统的各种不同的方案;然后分析员从这些供选择的方案中选取若干个合理的方案 , 从中选出一个最佳方案向用户和使用部门负责人推荐;分析员应该进一步为这个最佳方案设计软件结构 , 进行必要的数据库设计 , 确定测试要求并且制定测试计划 。
必要性:
总体设计可以站在全局高度上 , 花较少成本 , 从较抽象的层次上分析对比多种可能的系统实现方案和软件结构 , 从中选出最佳方案和最合理的软件结构 , 从而用较低成本开发出较高质量的软件系统 。
设计过程
由两个主要阶段组成:
1、系统设计阶段 , 确定系统的具体实现方案
■设想供选择的方案
■选取合理的方案
■推荐最佳方案
2、结构设计阶段 , 确定软件结构
■功能分解
■设计软件结构
■设计数据库
■制定测试计划
■书写文档
■审查和复审
典型的总体设计过程包括下述9个步骤: 1. 设想供选择的方案
根据需求分析阶段得出的数据流图考虑各种可能的实现方案 , 力求从中选出最佳方案 。
2. 选取合理的方案
从前一步得到的一系列供选择的方案中选取若干个合理的方案 。对每个合理的方案分析员都应该准备下列4份资料:
■系统流程图;
■组成系统的物理元素清单;
■成本/效益分析;
■实现这个系统的进度计划 。
3. 推荐最佳方案
分析员应该综合分析对比各种合理方案的利弊 , 推荐一个最佳的方案 , 并且为推荐的方案制定详细的实现计划 。
4. 功能分解
■首先进行结构设计 , 然后进行过程设计 。
■结构设计确定程序由哪些模块组成 , 以及这些模块之间的关系;过程设计确定每个模块的处理过程 。
■结构设计是总体设计阶段的任务 , 过程设计是详细设计阶段的任务 。
5. 设计软件结构
■通常程序中的一个模块完成一个适当的子功能 。应该把模块组织成良好的层次系统 。软件结构可以用层次图或结构图来描绘 。
■如果数据流图已经细化到适当的层次 , 则可以直接从数据流图映射出软件结构 , 这就是面向数据流的设计方法 。
6. 设计数据库
对于需要使用数据库的那些应用系统 , 软件工程师应该在需求分析阶段所确定的系统数据需求的基础上 , 进一步设计数据库 。
7. 制定测试计划
在软件开发的早期阶段考虑测试问题 , 能促使软件设计人员在设计时注意提高软件的可测试性 。
8. 书写文档