(工程设计)软件工程设计办法概述精品

上传人:管****问 文档编号:137951711 上传时间:2020-07-13 格式:DOC 页数:8 大小:23.18KB
返回 下载 相关 举报
(工程设计)软件工程设计办法概述精品_第1页
第1页 / 共8页
(工程设计)软件工程设计办法概述精品_第2页
第2页 / 共8页
(工程设计)软件工程设计办法概述精品_第3页
第3页 / 共8页
(工程设计)软件工程设计办法概述精品_第4页
第4页 / 共8页
(工程设计)软件工程设计办法概述精品_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《(工程设计)软件工程设计办法概述精品》由会员分享,可在线阅读,更多相关《(工程设计)软件工程设计办法概述精品(8页珍藏版)》请在金锄头文库上搜索。

1、山东轻工业学院教师授课教案课程名称:软件工程课程代码:0310040学 分:3课程类别:选修课开课单位:信息科学与技术学院授课班级:计科07-12授课教师:赵培英山东轻工业学院教务处制授课时间2009年 9 月 23 日 星期 三 第 34 节2009年 9 月 25 日 星期 五 第 34 节2009年 10 月 9 日 星期 五 第 34 节授课内容概要第四章 设计第一节 设计工程概述 设计的目标,设计的任务,软件设计的过程。第二节 软件设计原则 模块化,抽象与逐步求精,信息隐藏,模块独立。第三节 软件体系结构设计 各种体系结构风格。第四节 部件级设计技术结构化程序设计方法,设计的各种表示

2、方法。第五节 人机界面设计影响人机界面设计的因素,涉及的模型,人机界面设计的黄金规则。第六节 设计归档、确认与验证 设计文档应包含的内容,设计确认与验证的含义,设计评审的过程。目的要求了解设计的目标、任务、过程;了解结构化程序设计方法;了解设计的各种表示方法;了解人机界面设计的黄金规则;掌握软件设计原则;掌握各种体系结构风格;掌握设计评审的方法。重 点软件设计原则;各种体系结构风格;设计评审。难点耦合与内聚的概念及分类作业布置1.简述软件设计阶段的任务和目标?2.软件设计有哪些原则?3.简述模块、模块化及模块化设计的概念。4.举例说明各种类型的模块耦合和模块内聚。5.比较各种体系结构风格。6.

3、人机界面设计的黄金规则?7.如何进行设计评审?参考书1.软件工程理论与实践(第三版影印版),ShariLawrencePfleeger,高等教育出版社,2001年8月2软件工程钱乐秋等 清华大学出版社课 型理论课学时分配复 习 5 分钟主要教具多媒体讲 授 35 分钟教学方法多媒体课件指 导 2 分钟教学手段讲授结合实例总 结 3 分钟备注授课:每周二56,双周周五56,II公教JT301 答疑:每周四78节,机电C403学时分配:指本章节每节课(45分钟)的平均分配情况授 课 过 程 及 内 容:第四章 设计 软件设计原则 软件体系结构设计 部件级设计技术 人机界面设计 设计规约与设计评审一

4、、软件设计工程概述 软件设计的任务 软件设计的目标 软件设计的过程1软件设计的任务 设计过程解决“怎么做”的问题,把软件需求变换成软件表示的过程,主要包含两个阶段: 软件体系结构设计(概要设计) 部件级设计 (详细设计) 根据用信息域表示的软件需求,以及功能和性能需求,产生 数据/类设计 体系结构设计 接口设计 部件级设计 1)数据/类设计 类模型=类实现(数据结构) 在类和由CRC(类责任协作者)中定义的数据对象和关系以及数据字典中描述的详细数据内容提供了数据设计活动的基础2)体系结构设计 定义软件的整体结构 由软件部件、外部可见的属性和它们之间的关系组成。 体系结构设计表示可以从系统规约、

5、分析模型和分析模型中定义的子系统的交互导出。 3)接口设计 描述软件内部、与协作系统之间、与人之间如何通信,主要包括三个方面: 设计模块间接口 设计外部接口 设计人机接口 4)部件级设计 软件体系结构的结构性元素软件部件的过程性描述。 在编码步骤,根据这种过程性描述,生成源程序代码,然后通过测试最终得到完整有效的软件。 部件设计的基础:从类为基础的模型、流模型、行为模型中得到的信息 2软件设计的目标 1)设计必须实现分析模型中描述的所有显式需求,必须满足用户希望的所有隐式需求。2)设计必须是可读、可理解的,使得将来易于编程、易于测试、易于维护。3)设计应从实现角度出发,给出与数据、功能、行为相

6、关的软件全貌。3软件设计的过程 1)制定规范2)体系结构和接口设计3)数据/类设计4)部件级(过程)设计5)编写设计文档6)设计评审4软件设计原则(1)抽象化 软件系统进行模块设计时,可有不同的抽象层次。 在最高的抽象层次上,可以使用问题所处环境的语言概括地描述问题的解法。 在较低的抽象层次上,则采用过程化的方法。 包括过程抽象和数据抽象1) 过程的抽象:在软件工程中,从系统定义到实现,每进展一步都可以看做是对软件解决方法的抽象化过程的一次细化。 r需求分析阶段,用“问题所处环境的为大家所熟悉的术语”来描述软件解决方法。 r从概要设计到详细设计的过程中,抽象化的层次逐次降低。 r当产生源程序时

7、到达最低抽象层次。 2) 数据抽象:在不同层次上描述数据对象的细节,定义与该数据对象相关的操作。(2)逐步求精 将软件的体系结构按自顶向下方式,对各个层次的过程细节和数据细节逐层细化,直到用程序设计语言的语句能够实现为止,从而最后确立整个的体系结构 逐步求精与抽象是一对互补的概念(3)模块化 模块化:指整个软件被划分成若干单独命名和可编址的部分,称之为模块。这些模块可以被组装起来以满足整个问题的需求。 把问题子问题的分解与软件开发中的系统子系统或系统模块对应起来,就能够把一个大而复杂的软件系统划分成易于理解的比较单纯的模块结构。 模块化的理论根据“分而治之”(P66)(4)信息隐藏 每个模块的

8、实现细节对于其它模块来说应该是隐蔽的。即:块中所包含的信息(包括数据和过程)不允许其它不需要这些信息的模块使用 通过信息隐蔽,可使错误局部化 (5)模块独立 模块独立:是指软件系统中每个模块只涉及软件要求的具体的子功能, 而和软件系统中其它的模块的接口是简单的 一般采用两个准则度量模块独立性。即模块间耦合和模块内聚: 内聚(cohesion)是一个模块内部各个元素彼此结合的紧密程度的度量 耦合(coupling)是模块之间互相连接的紧密程度的度量 模块独立性比较强的模块应是高内聚低耦合的模块。1)内聚 内聚性分七种类型 . 功能内聚 (Functional Cohesion):模块中各部分都是

9、完成某一具体功能必不可少的组成部分。. 顺序内聚 (Sequential Cohesion):一个模块完成多个功能,各个功能必须顺序执行。. 通信内聚 (Communication Cohesion):一个模块内各功能部分都使用了相同的输入数据,或产生了相同的输出数据。. 过程内聚(Procedural Cohesion):一个模块完成多个任务,这些任务必须按指定的过程进行。. 时间内聚(Classical Cohesion):模块的各个功能的执行与时间有关,通常要求所有功能必须在同一时间段内执行。例如初始化模块和终止模块。. 逻辑内聚(Logical Cohesion):这种模块把几种相关的

10、功能组合在一起,调用时,由传送给模块的判定参数来确定该模块应执行哪一种功能。. 巧合内聚(Coincidental Cohesion):巧合内聚又称为偶然内聚。模块内各部分之间没有联系,或者即使有联系也很松散。2)耦合 模块间的耦合方式. 非直接耦合(Nondirect Coupling):两个模块之间没有直接关系,它们的联系完全是通过主模块的控制和调用来实现的。. 数据耦合 (Data Coupling):模块间仅通过参数表传递简单数据参数 (不是控制参数、公共数据结构或外部变量) 交换信息。. 标记耦合 (Stamp Coupling):模块间通过参数表传递一个数据结构的一部分(不是简单变

11、量。. 控制耦合 (Control Coupling):如果一个模块通过传送开关、标志、名字等控制信息,明显地控制选择另一模块的功能,就是控制耦合。. 外部耦合(External Coupling):一组模块都访问同一全局简单变量而不是同一全局数据结构,而且不是通过参数表传递该全局变量的信息,则称之为外部耦合。. 公共耦合(Common Coupling):若一组模块都访问同一个公共数据环境,则它们之间的耦合就称为公共耦合。公共的数据环境可以是全局数据结构、共享的通信区、内存的公共覆盖区等。公共耦合的复杂程度随耦合模块的个数增加而显著增加。若只是两模块间有公共数据环境,则公共耦合有两种情况。松

12、散公共耦合和紧密公共耦合。. 内容耦合 (Content Coupling):如发生下列情形,两个模块之间就发生了内容耦合:a) 一个模块直接访问另一个模块的内部数据;b) 一个模块不通过正常入口转到另一模块内部;c) 两个模块有一部分程序代码重迭(只可能出现在汇编语言中);d) 一个模块有多个入口。二、软件体系结构设计 软件体系结构设计的一个核心问题是能否使用重复的体系结构模式,即能否达到体系结构级的软件重用 软件体系结构风格是描述某一特定应用领域中系统组织方式的惯用模式。1软件体系结构的风格 (1)仓库风格体系结构 以数据为中心,有两种不同的构件:中央数据结构说明当前状态,独立构件在中央数

13、据存贮上执行,仓库与外构件间的相互作用在系统中会有大的变化 例子:数据库,黑板系统(2)数据流风格的体系结构 输入数据被一系列的构件变换成输出数据。 构件被称为过滤器,连接件为管道 过滤器必须是独立的实体,它不能与其它的过滤器共享数据,而且一个过滤器不知道它上游和下游的标识 例:编译程序(3)调用和返回风格的体系结构 非常容易修改和扩充的体系结构。 包含:主程序/子程序风格体系结构和远程过程调用风格的体系结构 在这里要了解几个概念: 程序结构的深度:程序结构的层次数称为结构的深度。结构的深度在一定意义上反映了程序结构的规模和复杂程度。 程序结构的宽度:层次结构中同一层模块的最大模块个数称为结构

14、的宽度。 模块的扇入和扇出:扇出表示一个模块直接调用(或控制)的其它模块数目。扇入则定义为调用(或控制)一个给定模块的模块个数。多扇出意味着需要控制和协调许多下属模块。而多扇入的模块通常是公用模块。(4)面向对象风格的体系结构 系统部件封装数据表示和数据操作。 部件之间通过消息来交互和协调。 (5)层次式风格的体系结构 定义不同的层次,每一层为上层服务,并作为下层客户二、评估可选的体系结构 同一软件需求,不同设计方法,导出不同的软件结构。 同一问题的不同软件结构:体系结构权衡分析法(ATAM,architecture trade-off analysis method) 在进行软件体系结构设计时,可以参考如下规则: (1)改进软件结构提高模块独立性(2)模块适当的深度、宽度、扇出和扇入(3)模块判断作用范围应在其控制作用范围内(4)力争降低模块接口的复杂度(5)设计单入口单出口的模块(6)模块功能应该是可以预测的模块大小适中

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 企业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号