版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第五章第五章第五章第五章第五章第五章 总体设计总体设计总体设计总体设计总体设计总体设计http:/ 总体设计的过程总体设计的过程5.1.1 设计供选择的方案设计供选择的方案需求分析阶段得出的数据流图是总体设计的根本出发点。 通常,选取的这些方案中至少应包括低成本、中成本和高成本的三种方案类型。对每个合理方案要提供以下几方面资料:(1)系统流程图;(2)数据字典;(3)成本效益分析;(4)实现这个系统的进度计划。5.1.2 推荐最佳方案推荐最佳方案分析员从合理方案中选择一个最佳方案向用户推荐,并为推荐的方案制定详细的实现计划。对于分析员推荐的最佳方案,用户和有关专家应该认真审查。如果确认该方案确
2、实符合用户的需要,并且在现有条件下完全能够实现,则应该提请使用部门负责人进一步审批。在使用部门负责人也接受了分析员所推荐的方案之后,方可进入总体设计过程的下一步工作,即结构设计阶段。 过程设计:确定每个模块的处理过程。结构设计:确定系统由哪些模块组成,以及这些模块之间的相互关系。5.1.3 设计软件结构设计软件结构 对于大型系统的设计,通常分为两个阶段:结构设计和过程设计。其中,结构设计是总体设计阶段的任务,而过程设计则是详细设计阶段的任务。5.1.4 数据库设计数据库设计 数据库的应用越来越广泛,目前大多数的系统都要用到数据库技术。数据库设计是一项专门的技术,包括模式设计、子模式设计、完整性
3、和安全性设计和优化处理等。 5.1.5 制定测试计划制定测试计划 在软件开发的早期阶段提前考虑软件的测试计划是很有必要的。这样能促使软件设计人员在设计时注意到软件的测试问题,从而有利于提高软件的可测试性。 总体设计阶段的文档总体设计阶段的文档(1)总体设计说明书(包括系统实现方案和软件模块结构);(2)测试计划(包括测试策略、测试方案、预测的测试结果、测试进度计划等);(3)用户手册(根据总体设计阶段的结果,编写的初步的用户操作手册);(4)详细的实现计划;(5)数据库设计结果。5. 2 软件设计基本原理软件设计基本原理模块:又称构件,是能够单独命名并独立地完成一定功能的程序语句的集合。例如高
4、级语言中的过程、函数、子程序等都可作为模块。5.2.1 模块化模块化模块化是软件的一个重要属性。模块化的特性提供了人们处理复杂的问题的一种方法,同时也使得软件能够被有效地管理。 这种“分而治之”的思想提供了模块化的根据:把复杂的问题分解成许多容易解决的小问题,原来的问题也就容易解决了。 根据前面的结论,我们可以得出下面的不等式:E(P1P2)E(P1)E(P2)这个不等式表明:单独解决问题P1和P2所需的工作量之和,比把P1和P2合起来作为一个问题来解决时所需的工作量要少。 有两个函数:C(x)表示问题x的复杂程度;E(x)表示解决问题x所需要的工作量(时间)。对于两个问题P1和P2,如果:C
5、(P1)C(P2)则:E(P1)E(P2)另一个有趣的特性是:C(P1P2)C(P1)C(P2)模块化和软件成本的关系模块化和软件成本的关系 M 软件总成本 成本或工作量 最小成本区 接口成本 模块数目 我们在考虑问题时,集中考虑和当前问题有关的方面,而忽略和当前问题无关的方面,这就是抽象。或者说抽象就是抽出事物的本质特性而暂时不考虑它们的细节。 5.2.2 抽象抽象软件工程过程的每一步,都是对软件解法的抽象层次的一次细化。在可行性研究阶段,软件被看作是一个完整的系统部分;在需求分析期间,我们使用在问题环境中熟悉的术语来描述软件的解法;当我们由总体设计阶段转入详细设计阶段时,抽象的程度进一步减
6、少;最后,当源程序写出来时,也就达到了抽象的最低层。 信息隐蔽原理认为:模块所包含的信息(过程和数据)对于其他模块来说应该是隐蔽的。也就是说,模块应当被这样规定和设计,使得包含在模块中的信息(过程或数据)对于其它不需要这些信息的模块来说,是不能访问的,或者说是“不可见”的。 5.2.3 信息隐蔽信息隐蔽信息隐蔽对于软件的测试与维护都有很大的好处。因为对于软件的其它部分来说,绝大多数数据和过程都是隐蔽的,这样,在修改期间由于疏忽而引入的错误所造成的影响就可以局限在一个或几个模块内部,不至波及到软件的其他部分。 模块的独立性是软件质量的关键:(1)模块化程度较高的软件容易开发;(2)模块化程度较高
7、的软件也比较容易测试和维护。5.2.4 模块独立性模块独立性模块的独立性的度量标准:耦合和内聚。 1、耦合、耦合耦合:软件结构中各个模块之间相互关联程度的度量。常见的耦合:(1)非直接耦合(2)数据耦合(3)标记耦合(4)控制耦合(5)公共耦合(6)内容耦合设计原则:尽量使用数据耦合,少用控制耦合,限制公共耦合的范围,避免使用内容耦合。2、内聚、内聚内聚:模块内部各个元素彼此结合的紧密程度的度量。常见的内聚:(1)偶然内聚(2)逻辑内聚(3)时间内聚(4)过程内聚(5)通信内聚(6)顺序内聚(7)功能内聚5. 3 设计准则设计准则1尽力提高模块独立性2选择合适的模块规模3模块的深度、宽度、扇出
8、和扇入应适当4模块的作用范围应该在控制范围之内5降低模块接口的复杂程度6设计单入口单出口的模块,避免“病态连接”5. 4 总体设计的图形描述工具总体设计的图形描述工具5.4.1 层次图层次图正文加工系统输入输出编辑加标题存储检索编目录格式化添加删除插入修改合并列表 正文加工系统的层次图5.4.2 HIPO图图带编号的层次图(H图)正文加工系统输入1.0输出2.0编辑3.0加标题4.0存储5.0检索6.0编目录7.0格式化8.0添加3.1删除3.2插入3.3修改3.4合并3.5列表 结构图结构图软件结构图的基本符号AB(a) 基本形式ACBD(b) 顺序ABC(c) 选择AB(d
9、) 重复产生最佳解的结构图格式化的解解产生最佳解计算最佳解得到好输入编辑输入读输入原始输入编辑结果原始输入输出结果显示结果结果格式化解格式化的解好输入好输入解5. 5 结构化设计方法结构化设计方法5.5.1 数据流图的类型数据流图的类型1、变换型数据流图、变换型数据流图输入变换输出2、事务型数据流图、事务型数据流图事务中心活动通路T事务5.5.2 设计步骤设计步骤复查满意精化数据流图类型区分事务中心和数据接收通路映射成事务结构区分输入和输出分支映射成变换结构“事务”“变换”优化软件结构导出软件结构详细设计不满意5.5.3 变换设计变换设计我们通过一个汽车数字仪表板的设计来介绍变换分析的过程。假
10、设仪表板的功能如下:(1)通过模数(AD)转换实现传感器和微处理机接口;(2)在发光二极管(LCD)面板上显示数据;(3)指示每小时英里数(mph),行驶的里程,每加仑油行驶的英里数(mpg)等等;(4)指示加速或减速;(5)超速警告:如果车速超过55英里小时,则发出超速警告铃声。在软件需求分析阶段,应该对上述每项性能和其它要求进行全面的分析,并建立起相应的文档资料,得出数据流图。具体的设计步骤如下:1、复查基本、复查基本系统模型系统模型2、复查并精化、复查并精化数据流图数据流图SPSmph超速值计算里程产生加速/减速显示读入旋转信号收集并求平均旋转信号信号数/秒(SPS)确定加速/减速箭头指
11、示下箭头水平线上箭头转换成转/分(rpm)计算mph和超速值计算燃料消耗产生mpg显示读入并核实计算gph燃料流量传感器信号燃料流量gphmphmpgmpg显示产生里程显示英里显示发出警告铃声警告铃声产生mph显示mph显示rpmSPSrpm3、确定数据流图的类型、确定数据流图的类型这一步的任务是确定数据流图是变换型数据流图还是事务型数据流图。从上图中可以看出,数据沿着两条输入通路(旋转信号和燃料流量传感器信号)进入系统,然后沿着五条通路(4个显示,一个警告铃声)离开,没有明显的事务中心(虽然变换“计算mph与超速值”可以看作是一个事务中心)。因此,可以认为这个数据流图的类型是变换型数据流图。
12、4、确定输入流和输出流的边界,从而孤立出变换中心、确定输入流和输出流的边界,从而孤立出变换中心SPSrpmmpg 显示gphmpgmph(SPS)mph超速值计算里程读入旋转信号收集并求平均旋转信号信号数/秒确定加速/减速箭头指示产生加速/减速显示下箭头水平线上箭头转换成转/分(rpm)计算mph 和超速值计算燃料消耗产生mpg显示读入并核实计算gph燃料流量传感器信号燃料流量产生里程显示英里显示发出警告铃声警告铃声产生mph显示mph 显示SPSrpm5、进行、进行“第一级分解第一级分解”CmCtCaCe第一级分解的方法第一级分解的结果数字仪表板控制数据转换控制接收传感器信号驱动仪表板输入控
13、制变换控制输出控制6、进行、进行“第二级分解第二级分解”第二级分解的方法BADCCmCa CB D A第二级分解的结果:接收传感器信号转换成 rpm计算 gph收集 sps读旋转信号读燃料流量接收传感器信号确定加速/减速计算 mph计算 mpg计算里程 未经精化的输入结构 未经精化的变换结构 未经精化的输出结构驱动仪表板加速/减速显示显示 mpg显示里程发出警告铃声显示 mph发光二极管显示7、使用设计度量和设计准则对第一次分割、使用设计度量和设计准则对第一次分割得到的软件结构进一步精化得到的软件结构进一步精化 对于从前面的设计步骤得到的软件结构,还可以进行许多修改:(1)输入结构中的模块“转换成rpm”和“收集sps”可以合并;(2)模块“确定加速减速”可以放在模块“计算mph”下面,以减少耦合;(3)模块“加速减速显示”可以相应地放在模块“显示mph”的下面。精化的数字仪表板系统的软件结构数字仪表板控制接收传感器信号数据转换控制驱动仪表板计算里程计算mpg计算mph计算gph转换成rpm发出警报铃声显示里程显示mpg显示mph读
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年液态食品包装机械行业分析报告及未来发展趋势报告
- 基于小样本域适应的唇语识别算法研究及系统实现
- 武胜县2026年公开招聘社区工作者(62人)考试备考题库及答案解析
- 2026年音频电话系统行业分析报告及未来发展趋势报告
- 2026江西南昌航空大学招聘硕士及以下人员9人考试备考试题及答案解析
- 文学文本人工翻译与机器翻译语言计量特征对比研究
- 2026年深度学习及其应用-复旦大学中国大学mooc课后章节答案期末考试模拟试卷A4版附答案详解
- 2026年纺织过滤材料行业分析报告及未来发展趋势报告
- 2026年铧式犁行业分析报告及未来发展趋势报告
- 2026海南安保控股有限责任公司招聘4人考试备考试题及答案解析
- 生态环境影响评价合同范本2026
- 2026年骨科副主任医师职称考试历年真题及答案
- 2026届福建省厦门市高三三检英语试题(含答案和音频)
- 2026年反兴奋剂检查官考试兴奋剂检查违规情形识别题
- 银川市、石嘴山市、吴忠市三市2026年高三年级学科教学质量检测数学+答案
- 2026四川成都产业投资集团有限公司所属公司招聘5人笔试历年参考题库
- 《智能产品设计》全套教学课件
- 【715】《老年护理服务能力提升行动方案》深度解读
- (2026春新版)部编版八年级语文下册全册教案
- 雨课堂学堂在线学堂云《Hospitality English(南开)》单元测试考核答案
- GB 12801-2025生产过程安全基本要求
评论
0/150
提交评论