清华大学殷仁昆教授讲授《软件工程》讲义-03_第1页
清华大学殷仁昆教授讲授《软件工程》讲义-03_第2页
清华大学殷仁昆教授讲授《软件工程》讲义-03_第3页
清华大学殷仁昆教授讲授《软件工程》讲义-03_第4页
清华大学殷仁昆教授讲授《软件工程》讲义-03_第5页
已阅读5页,还剩89页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、软件工程软件工程94-94-1 16:21:24软件工程软件工程第三章第三章 软件设计软件设计3.1 3.1 软件设计的概念软件设计的概念3.2 3.2 功能独立性功能独立性3.3 3.3 结构化设计方法结构化设计方法3.4 3.4 过程设计过程设计清华大学计算机系清华大学计算机系 殷人昆殷人昆软件工程软件工程94-94-2 26:21:243.1 3.1 软件设计的概念软件设计的概念n软件设计的基本目标是软件设计的基本目标是用比较抽象概括的方式用比较抽象概括的方式确定目标系统如何完成预定的任务确定目标系统如何完成预定的任务,即软件设,即软件设计是确定系统的物理模型。计是确定系统的物理模型。n

2、从技术观点来看,软件设计包括从技术观点来看,软件设计包括数据设计数据设计、体体系结构设计系结构设计、接口设计接口设计、过程设计过程设计。n数据设计数据设计将实体关系图中描述的对象和关系,将实体关系图中描述的对象和关系,以及数据字典中描述的详细数据内容转化为数以及数据字典中描述的详细数据内容转化为数据结构的定义。据结构的定义。软件工程软件工程94-94-3 36:21:24 体系结构设计体系结构设计定义软件系统各主要成份之间的定义软件系统各主要成份之间的关系。关系。 接口设计接口设计根据数据流图定义软件内部各成份之根据数据流图定义软件内部各成份之间、软件与其它协同系统之间及软件与用户之间、软件与

3、其它协同系统之间及软件与用户之间的交互机制。间的交互机制。 过程设计过程设计则是把结构成份转换成软件的过程性则是把结构成份转换成软件的过程性描述。描述。软件工程软件工程94-94-4 46:21:24将分析模型转换为设计将分析模型转换为设计数据字典数据字典数数据据流流图图实实体体关关系系图图状态转换图状态转换图加加工工规规格格说说明明控控制制规规 格格说说明明数数据据对对象象描描述述过程设计过程设计接口设计接口设计体系结构设计体系结构设计数据设计数据设计软件工程软件工程94-94-5 56:21:25n从工程管理角度来看,软件设计分两步完成:从工程管理角度来看,软件设计分两步完成:概要设计和详

4、细设计。概要设计和详细设计。n概要设计概要设计将软件需求将软件需求转化为软件体系结构转化为软件体系结构确定系统级接口确定系统级接口全局数据结构或数据库模式。全局数据结构或数据库模式。n详细设计详细设计确立每个模块的实现算法和局部数据结构确立每个模块的实现算法和局部数据结构用适当方法表示算法和数据结构的细节用适当方法表示算法和数据结构的细节软件工程软件工程94-94-6 66:21:25n软件设计是后续开发步骤及软件维护工作的基软件设计是后续开发步骤及软件维护工作的基础。如果没有设计,只能建立一个不稳定的系础。如果没有设计,只能建立一个不稳定的系统结构。统结构。设计设计编码编码测试测试维护维护测

5、试测试编码编码维护维护有软件设计有软件设计 没有软件设计没有软件设计软件工程软件工程94-94-7 76:21:25n软件设计既是过程又是模型。软件设计既是过程又是模型。n设计过程设计过程是一系列的迭代步骤,使设计人员能是一系列的迭代步骤,使设计人员能够描述目标系统的各个侧面。够描述目标系统的各个侧面。n设计模型设计模型首先描述目标系统的整体架构,然后首先描述目标系统的整体架构,然后逐步细化架构得到构造每个细节的指导原则,逐步细化架构得到构造每个细节的指导原则,从而得到系统的一系列不同的视图。从而得到系统的一系列不同的视图。n良好的设计原则可为设计过程导航。良好的设计原则可为设计过程导航。n衡

6、量衡量设计过程设计过程的技术原则:的技术原则: 设计必须实现分析模型中描述的所有显式需设计必须实现分析模型中描述的所有显式需求,必须满足用户希望的所有隐式需求。求,必须满足用户希望的所有隐式需求。衡量软件设计的原则衡量软件设计的原则软件工程软件工程94-94-8 86:21:25 对于开发者和未来的维护者而言,对于开发者和未来的维护者而言,设计必须设计必须是可读的、可理解的,使得将来易于编程、是可读的、可理解的,使得将来易于编程、易于测试、易于维护。易于测试、易于维护。 设计应该给出软件的全貌,包括从实现角度设计应该给出软件的全貌,包括从实现角度可看到的数据、功能、行为。可看到的数据、功能、行

7、为。n衡量衡量设计模型设计模型的技术原则的技术原则 设计模型应该是一个分层结构。该结构:设计模型应该是一个分层结构。该结构: 使用可识别的使用可识别的设计模式设计模式搭建系统结构。搭建系统结构。 用显示良好设计特征的用显示良好设计特征的构件构件构成。构成。 可以用可以用演化的方式演化的方式实现。实现。 设计应当模块化。设计应当模块化。软件工程软件工程94-94-9 96:21:25 设计应当包含数据、体系结构、接口和构件设计应当包含数据、体系结构、接口和构件(模块)的清晰的视图。(模块)的清晰的视图。 设计应当根据将要实现的对象和数据模式导出设计应当根据将要实现的对象和数据模式导出合适的数据结

8、构。合适的数据结构。 设计应当建立具有独立功能特征的构件。设计应当建立具有独立功能特征的构件。 设计应当建立能够降低模块与外部环境之间复设计应当建立能够降低模块与外部环境之间复杂连接的接口。杂连接的接口。 设计模型应当通过使用软件需求信息所驱动的设计模型应当通过使用软件需求信息所驱动的可重复的方法导出。可重复的方法导出。nDavis的软件设计原则的软件设计原则 设计应具有设计应具有可跟踪性可跟踪性,能回溯到软件需求,能回溯到软件需求;软件工程软件工程94-94-10106:21:25 设计不必每次都从头做起,可以复用已有的设计不必每次都从头做起,可以复用已有的设计模式和数据模式。设计模式和数据

9、模式。 设计应当缩小软件与现实世界中问题的设计应当缩小软件与现实世界中问题的“智智力距离力距离”,尽量逼近问题领域的结构,尽量逼近问题领域的结构; 设计应具有一致性和集成性。整个系统应具设计应具有一致性和集成性。整个系统应具有统一的风格和格式,具有良好的接口。有统一的风格和格式,具有良好的接口。 设计结果应能适应未来可能的变更设计结果应能适应未来可能的变更; 设计不是编码,编码也不是设计。设计模型设计不是编码,编码也不是设计。设计模型的抽象级别比源代码高。在编码级别上唯一的抽象级别比源代码高。在编码级别上唯一的设计决策是补充一些实现细节。的设计决策是补充一些实现细节。软件工程软件工程94-94

10、-11 116:21:25 设计应具有容错性和异常处理能力。对于异设计应具有容错性和异常处理能力。对于异常数据、事件、操作条件等能够平滑处理。常数据、事件、操作条件等能够平滑处理。 在建立设计方案时就应能评估设计质量,而在建立设计方案时就应能评估设计质量,而不是在系统编码之后。不是在系统编码之后。 应坚持设计评审,减少概念性(语义性)的应坚持设计评审,减少概念性(语义性)的错误。错误。1)设计应遵循设计应遵循抽象化抽象化的原则,的原则,数据抽象数据抽象软件设计的主要手段软件设计的主要手段软件工程软件工程94-94-12126:21:25 过程抽象过程抽象 是指在软件设计中将处理过程的是指在软件

11、设计中将处理过程的实现细节隐藏在数据抽象中,可以直接通过实现细节隐藏在数据抽象中,可以直接通过模块接口使用这些处理操作模块接口使用这些处理操作。 数据抽象数据抽象 是指采用抽象数据类型表示数据,是指采用抽象数据类型表示数据,实现数据封装,使得使用者可通过接口使用实现数据封装,使得使用者可通过接口使用数据而不必关心数据结构的实现。数据而不必关心数据结构的实现。2.设计应遵循设计应遵循自顶向下自顶向下、逐步细化逐步细化的原则,建立的原则,建立一个层次的结构。一个层次的结构。 将软件体系结构自顶向下,对过程细节和数将软件体系结构自顶向下,对过程细节和数据细节从抽象到具体,逐层细化,直到用编据细节从抽

12、象到具体,逐层细化,直到用编程语言的语句能够实现为止。程语言的语句能够实现为止。软件工程软件工程94-94-13136:21:254)设计应当遵循设计应当遵循模块化模块化的原则的原则。 每个模块可独立地开发、测试,最后组装成每个模块可独立地开发、测试,最后组装成完整的程序。完整的程序。 其出发点是本着将一种复杂问题其出发点是本着将一种复杂问题“分而治之分而治之”的原则。其目的是使程序的结构清晰,容易的原则。其目的是使程序的结构清晰,容易阅读、理解、测试、修改。阅读、理解、测试、修改。 Meyer的的良好模块设计方法的标准良好模块设计方法的标准a) 模块可分解性模块可分解性 可将系统按问题子问题

13、可将系统按问题子问题分解的原则分解成系统的模块层次结构分解的原则分解成系统的模块层次结构;b) 模块可组装性模块可组装性 可利用已有的设计构件组可利用已有的设计构件组装成新系统,不必一切从头开始。装成新系统,不必一切从头开始。软件工程软件工程94-94-14146:21:25c) 模块可理解性模块可理解性 一个模块可不参考其他模一个模块可不参考其他模块而被理解;块而被理解;d) 模块连续性模块连续性 对软件需求的一些微小变更对软件需求的一些微小变更只导致对某个模块的修改而整个系统不只导致对某个模块的修改而整个系统不用大动用大动;e) 模块保护模块保护 将模块内出现异常情况的影响将模块内出现异常

14、情况的影响范围限制在模块内部;范围限制在模块内部;5)设计应遵循设计应遵循信息隐蔽信息隐蔽的原则的原则。 Patnas主张在开发时,将每个程序的成分隐主张在开发时,将每个程序的成分隐藏在模块内,定义每一个模块时尽可能少藏在模块内,定义每一个模块时尽可能少地显露其内部的处理。地显露其内部的处理。软件工程软件工程94-94-15156:21:25 每个模块的实现细节对于其它模块是隐蔽的,每个模块的实现细节对于其它模块是隐蔽的,将来修改软件时偶然引入错误所造成的影响将来修改软件时偶然引入错误所造成的影响就可以局限在一个或几个模块内部,不致波就可以局限在一个或几个模块内部,不致波及到软件的其它部分。及

15、到软件的其它部分。 在可预见将来可能修改的场合,信息隐蔽可在可预见将来可能修改的场合,信息隐蔽可以提高软件的可修改性、可测试性和可移植以提高软件的可修改性、可测试性和可移植性。性。软件工程软件工程94-94-16166:21:253.2 3.2 功能独立性功能独立性n功能独立性是抽象、模块化和信息隐蔽的直接功能独立性是抽象、模块化和信息隐蔽的直接产物。如果一个模块能够独立于其他模块被编产物。如果一个模块能够独立于其他模块被编程、测试和修改,则该模块具有功能独立性。程、测试和修改,则该模块具有功能独立性。n1978年年Myers提出用两个准则来度量功能独立提出用两个准则来度量功能独立性,即模块间

16、的耦合和模块的内聚。性,即模块间的耦合和模块的内聚。n内聚性内聚性:内聚是一个模块内部各个元素彼此结:内聚是一个模块内部各个元素彼此结合的紧密程度的度量。合的紧密程度的度量。n耦合性耦合性: 耦合是模块间互相连接的紧密程度的耦合是模块间互相连接的紧密程度的度量,它取决于各个模块之间接口的复杂度、度量,它取决于各个模块之间接口的复杂度、调用方式以及哪些信息通过接口。调用方式以及哪些信息通过接口。软件工程软件工程94-94-17176:21:25非直接非直接 数据数据 标记标记 控制控制 外部外部 公共公共 内容内容 耦合耦合 耦合耦合 耦合耦合 耦合耦合 耦合耦合 耦合耦合 耦合耦合耦合性耦合性

17、功能独立性功能独立性模块间的耦合模块间的耦合n模块之间耦合性越强,功能独立性越差,这样模块之间耦合性越强,功能独立性越差,这样形成的模块结构界面不好。形成的模块结构界面不好。软件工程软件工程94-94-18186:21:25非直接耦合非直接耦合(Nondirect(Nondirect Coupling) Coupling)n两个模块之间没有直接关系,它们之间的联系完两个模块之间没有直接关系,它们之间的联系完全是通过主模块的控制和调用来实现的。全是通过主模块的控制和调用来实现的。n非直接耦合的模块独立性最强。非直接耦合的模块独立性最强。主模块主模块ABCEFGXYZ软件工程软件工程94-94-1

18、9196:21:25数据耦合数据耦合 (Data Coupling)(Data Coupling)n一个模块访问另一个模块时,彼此之间是通过简一个模块访问另一个模块时,彼此之间是通过简单数据参数单数据参数 (不是控制参数、公共数据结构或外不是控制参数、公共数据结构或外部变量部变量) 来交换输入、输出信息的。来交换输入、输出信息的。p0 (x0, y0) p1 (x1, y1)数据耦合数据耦合 LINE ( x0, y0, x1, y1)软件工程软件工程94-94-20206:21:25标记耦合标记耦合 (Stamp Coupling)(Stamp Coupling)n一组模块通过参数表传递记录

19、信息,就是标记耦一组模块通过参数表传递记录信息,就是标记耦合。这个记录是某一数据结构的子结构,而不是合。这个记录是某一数据结构的子结构,而不是简单变量。简单变量。p0 (x0, y0) p1 (x1, y1)标记标记耦合耦合 LINE ( p0, p1)软件工程软件工程94-94-21216:21:25控制耦合控制耦合 (Control Coupling)(Control Coupling)n如果一个模块通过如果一个模块通过传送开关、标志、传送开关、标志、名字等控制参数,名字等控制参数,明显地控制选择另明显地控制选择另一模块的功能,就一模块的功能,就是控制耦合。是控制耦合。FlagFlagf1

20、f2fn软件工程软件工程94-94-22226:21:25外部耦合(外部耦合(External CouplingExternal Coupling)n一组模块都访问同一全局简单变量而不是同一一组模块都访问同一全局简单变量而不是同一全局数据结构,而且不是通过参数表传递该全全局数据结构,而且不是通过参数表传递该全局变量的信息,则称之为外部耦合。局变量的信息,则称之为外部耦合。公共耦合(公共耦合(Common CouplingCommon Coupling)n若一组模块都访问同一个公共数据环境,则它若一组模块都访问同一个公共数据环境,则它们之间的耦合就称为公共耦合。公共的数据环们之间的耦合就称为公共

21、耦合。公共的数据环境可以是全局数据结构、共享的通信区、内存境可以是全局数据结构、共享的通信区、内存的公共覆盖区等。的公共覆盖区等。软件工程软件工程94-94-23236:21:25n公共耦合的复杂程度随耦合模块的个数增加而公共耦合的复杂程度随耦合模块的个数增加而显著增加。若只是两模块间有公共数据环境,显著增加。若只是两模块间有公共数据环境,则公共耦合有两种情况。松散公共耦合和紧密则公共耦合有两种情况。松散公共耦合和紧密公共耦合。公共耦合。common公共数据区公共数据区ABcommon公共数据区公共数据区AB松散的公共耦合松散的公共耦合紧密的公共耦合紧密的公共耦合软件工程软件工程94-94-2

22、4246:21:25n如果发生下列情形,模块之间就是内容耦合如果发生下列情形,模块之间就是内容耦合: 一个模块直接访问另一个模块的内部数据一个模块直接访问另一个模块的内部数据; 一个模块不通过正常入口转到另一模块内一个模块不通过正常入口转到另一模块内部部; 两个模块有一部分程序代码重迭两个模块有一部分程序代码重迭(只可能出只可能出现在汇编语言中现在汇编语言中); 一个模块有多个入口。一个模块有多个入口。内容耦合内容耦合 (Content Coupling)(Content Coupling)软件工程软件工程94-94-25256:21:25 c AB进入另一模块内部进入另一模块内部模块代码重叠

23、模块代码重叠ABentry1 entry2 模块多个入口模块多个入口软件工程软件工程94-94-26266:21:25模块内聚模块内聚巧合巧合 逻辑逻辑 时间时间 过程过程 通信通信 信息信息 功能功能内聚内聚 内聚内聚 内聚内聚 内聚内聚 内聚内聚 内聚内聚 内聚内聚内聚性内聚性功能独立性功能独立性n模块内聚性越强,功能独立性越好,对于形成模块内聚性越强,功能独立性越好,对于形成的模块结构有比较好的作用。的模块结构有比较好的作用。n要求模块结构达到高内聚,低耦合。要求模块结构达到高内聚,低耦合。软件工程软件工程94-94-27276:21:25n一个模块中各个部分都是完成某一具体功能必一个模

24、块中各个部分都是完成某一具体功能必不可少的组成部分,或者说该模块中所有部分不可少的组成部分,或者说该模块中所有部分都是为了完成一项具体功能而协同工作,紧密都是为了完成一项具体功能而协同工作,紧密联系,不可分割的。则称该模块为功能内聚模联系,不可分割的。则称该模块为功能内聚模块。块。n功能内聚模块的功能独立性最强。功能内聚模块的功能独立性最强。功能内聚功能内聚 (Functional Cohesion)(Functional Cohesion)软件工程软件工程94-94-28286:21:25n这种模块完成多个功能,各个功能相互独立但这种模块完成多个功能,各个功能相互独立但都在同一数据结构上操作

25、,每一项功能有一个都在同一数据结构上操作,每一项功能有一个唯一的入口点。这个模块将根据不同的要求,唯一的入口点。这个模块将根据不同的要求,确定该执行哪一个功能。确定该执行哪一个功能。n由于这个模块的所有功能都是基于同一个数据由于这个模块的所有功能都是基于同一个数据结构(符号表),因此,它是一个信息内聚的结构(符号表),因此,它是一个信息内聚的模块。模块。n信息内聚模块可以看成是多个功能内聚模块的信息内聚模块可以看成是多个功能内聚模块的组合,并且达到信息的隐蔽。组合,并且达到信息的隐蔽。信息内聚信息内聚 (Informational Cohesion)(Informational Cohesio

26、n)软件工程软件工程94-94-29296:21:25初始化初始化插入插入删除删除查找查找修改修改符符 号号 表表软件工程软件工程94-94-30306:21:25n如果一个模块内各功能部分都使用了相同的输如果一个模块内各功能部分都使用了相同的输入数据,或产生了相同的输出数据,则称之为入数据,或产生了相同的输出数据,则称之为通信内聚模块。通常,通信内聚模块是通过数通信内聚模块。通常,通信内聚模块是通过数据流图来定义的。据流图来定义的。n模块内各个功能是紧密相连的。模块内各个功能是紧密相连的。通信内聚通信内聚 (Communication Cohesion)(Communication Cohe

27、sion)软件工程软件工程94-94-31316:21:25打印打印检验结检验结果果读文件读文件文件文件计算计算A计算计算B合并合并修改修改文件文件新文件新文件A结果结果B结果结果软件工程软件工程94-94-32326:21:25n使用流程图做为工具设计程序时,如果流程图使用流程图做为工具设计程序时,如果流程图太大,可以把流程图中的某一部分划出组成模太大,可以把流程图中的某一部分划出组成模块,就得到过程内聚模块。块,就得到过程内聚模块。n例如,把流程图中的循环部分、判定部分、计例如,把流程图中的循环部分、判定部分、计算部分分成三个模块,这三个模块都是过程内算部分分成三个模块,这三个模块都是过程

28、内聚模块。聚模块。过程内聚(过程内聚(Procedural CohesionProcedural Cohesion)软件工程软件工程94-94-33336:21:25n时间内聚又称为经典内聚。这种模块大多为多时间内聚又称为经典内聚。这种模块大多为多功能模块,但模块的各个功能的执行与时间有功能模块,但模块的各个功能的执行与时间有关,通常要求所有功能必须在同一时间段内执关,通常要求所有功能必须在同一时间段内执行。行。n例如,初始化模块和终止模块就是时间内聚模例如,初始化模块和终止模块就是时间内聚模块。块。时间内聚(时间内聚(Classical CohesionClassical Cohesion)

29、软件工程软件工程94-94-34346:21:25n这种模块把几种相关的功能组合在一起,每次这种模块把几种相关的功能组合在一起,每次被调用时,由传送给模块的判定参数来确定该被调用时,由传送给模块的判定参数来确定该模块应执行哪一种功能。模块应执行哪一种功能。写一个记录写一个记录读一个记录读一个记录判定判定调用模块调用模块被调用被调用模块模块逻辑内聚(逻辑内聚(Logical CohesionLogical Cohesion)软件工程软件工程94-94-35356:21:25n当几个模块内正好有一段代码是相同的,将它们当几个模块内正好有一段代码是相同的,将它们抽取出来形成单独的模块,即巧合内聚模块

30、。这抽取出来形成单独的模块,即巧合内聚模块。这种模块没有独立功能,各部分之间没有联系,或种模块没有独立功能,各部分之间没有联系,或联系很松散。联系很松散。巧合内聚(巧合内聚(Coincidental CohesionCoincidental Cohesion)ABCM STORE REC() TO N READ MASTER FILE ADD 1 TO x 软件工程软件工程94-94-36366:21:25n结构化设计(结构化设计(structured design,SD)是一)是一种面向数据流的设计方法,它可以与种面向数据流的设计方法,它可以与SA方法方法衔接。衔接。n结构化设计是基于模块化

31、、自顶向下细化、结构化设计是基于模块化、自顶向下细化、结构化程序设计等程序设计技术基础上发展结构化程序设计等程序设计技术基础上发展起来的。基本思想是将系统设计成由相对独起来的。基本思想是将系统设计成由相对独立、功能单一的模块组成的结构。立、功能单一的模块组成的结构。n该方法实施的要点是:该方法实施的要点是:1) 首先首先研究研究、分析和审查数据流图分析和审查数据流图。 从软件从软件3.3 3.3 结构化设计方法结构化设计方法软件工程软件工程94-94-37376:21:25的需求规格说明中弄清数据流加工的过程,的需求规格说明中弄清数据流加工的过程,对于发现的问题及时解决。对于发现的问题及时解决

32、。2) 然后然后根据数据流图确定数据处理的类型根据数据流图确定数据处理的类型。典型的类型有两种:变换型和事务型。针典型的类型有两种:变换型和事务型。针对两种对两种不同类型分别进行分析处理。不同类型分别进行分析处理。3) 由数据流图推导由数据流图推导出系统的初始结构图出系统的初始结构图。4) 利用一些启发式原则利用一些启发式原则改进系统初始结构图改进系统初始结构图,直到得到符合要求的结构图为止。直到得到符合要求的结构图为止。5) 修改和补充数据字典。修改和补充数据字典。6) 制定制定测试计划。测试计划。软件工程软件工程94-94-38386:21:25在系统结构图中的模块在系统结构图中的模块n传

33、入模块传入模块 从下属模块取得数据,经过某些从下属模块取得数据,经过某些处理处理, 再将其传送给上级模块。它传送的数据再将其传送给上级模块。它传送的数据流叫做逻辑输入数据流。流叫做逻辑输入数据流。n传出模块传出模块 从上级模块获得数据,进行某些从上级模块获得数据,进行某些处理,再将其传送给下属模块。它传送的数处理,再将其传送给下属模块。它传送的数据流叫做逻辑输出数据流。据流叫做逻辑输出数据流。n变换模块变换模块 它从上级模块取得数据,进行特它从上级模块取得数据,进行特定的处理,转换成其它形式定的处理,转换成其它形式, 再传送回上级模再传送回上级模块。块。软件工程软件工程94-94-39396:

34、21:26n协调模块协调模块 对所有下属模块进行协调和管理对所有下属模块进行协调和管理的模块。的模块。传入模块传入模块AA传出模块传出模块DD变换模块变换模块AB协调模块协调模块AABB软件工程软件工程94-94-40406:21:26系统结构图的基本符号系统结构图的基本符号模块模块调用调用数据数据控制信息控制信息转接符号转接符号系统结构图的基本符系统结构图的基本符号号选择(判断)选择(判断)重复重复软件工程软件工程94-94-41416:21:26模块调用示例模块调用示例(a) 调用调用(b) 判断调用判断调用(c) 循环调用循环调用软件工程软件工程94-94-42426:21:26n数据数

35、据:模块之间传送的数据用:模块之间传送的数据用带空心圆的箭头带空心圆的箭头表示,并在旁边标上数据名。表示,并在旁边标上数据名。n控制信息控制信息:控制信息与数据的主要区别是前者:控制信息与数据的主要区别是前者只反映数据的某种状态。只反映数据的某种状态。模块间的数据传递模块间的数据传递AB(a)xyz查职工简历查职工简历读人事文件读人事文件(b)职工号职工号简历数据简历数据无此职工无此职工软件工程软件工程94-94-43436:21:26数据处理的类型数据处理的类型 n在需求分析阶段,面向数据流的在需求分析阶段,面向数据流的SA方法产生数方法产生数据流图据流图DFD。n在软件设计阶段,面向数据流

36、的在软件设计阶段,面向数据流的SD方法将方法将DFD转换成程序结构图。转换成程序结构图。n数据处理即为在数据处理即为在DFD中从系统的输入数据流到中从系统的输入数据流到系统的输出数据流所经历的一连串连续变换。系统的输出数据流所经历的一连串连续变换。n数据处理的类型分为变换流型与事务流型。数据处理的类型分为变换流型与事务流型。 软件工程软件工程94-94-44446:21:26变换流变换流 n数据沿着数据沿着输入通路输入通路进入系统,经过一系列数进入系统,经过一系列数据变换,将数据的外部形式转换成对应的内据变换,将数据的外部形式转换成对应的内部表示,然后通过部表示,然后通过变换中心变换中心(也称

37、主加工)(也称主加工)处理,再沿着处理,再沿着输出通路输出通路转换成外部形式离开转换成外部形式离开系统。具有这种特性的数据流称为变换流。系统。具有这种特性的数据流称为变换流。n变换流型变换流型DFD可以分成:可以分成: 输入变换中心(主加工)输出输入变换中心(主加工)输出 输入数据输入数据C变换数据变换数据CD输出数据输出数据D软件工程软件工程94-94-45456:21:26n相应于取得数据、变换数据、给出数据,变相应于取得数据、变换数据、给出数据,变换流型系统结构图由输入、变换中心和输出换流型系统结构图由输入、变换中心和输出等三部分组成。等三部分组成。主模块主模块B变换成变换成C输入输入B

38、输出输出CA变换成变换成B输入输入AC变换成变换成D输出输出DAABBBCCCDD软件工程软件工程94-94-46466:21:26事务事务流流 n数据沿着数据沿着输入通路输入通路到达一个到达一个事务中心事务中心,事务,事务中心根据输入数据(即事务)的类型在若干中心根据输入数据(即事务)的类型在若干个动作(称为活动流)中选择一个来执行,个动作(称为活动流)中选择一个来执行,这种数据流也称为事务流。这种数据流也称为事务流。n事务流有明显的事务中心,各活动流以事务事务流有明显的事务中心,各活动流以事务中心为起点呈辐射状流出。中心为起点呈辐射状流出。n在事务流型系统结构图中,事务中心模块按在事务流型

39、系统结构图中,事务中心模块按所接受的事务的类型,选择某一事务(活动所接受的事务的类型,选择某一事务(活动流)处理模块执行。各事务处理模块并列。流)处理模块执行。各事务处理模块并列。软件工程软件工程94-94-47476:21:26事务中心事务中心分派模块分派模块输出结果输出结果事务事务1输入作业信息输入作业信息事务事务2事务事务3事务事务4作业信息作业信息作业作业信息信息结果结果结果结果操作操作1操作操作2操作操作3操作操作4操作操作5操作操作6细节细节1细节细节2细节细节3细节细节4细节细节5细节细节6软件工程软件工程94-94-48486:21:26变换分析变换分析 n变换分析从变换流型的

40、数据流图导出系统结变换分析从变换流型的数据流图导出系统结构图构图.n步骤步骤1. 重画数据流图;重画数据流图;2. 区分有效(逻辑)输入、有效(逻辑)输区分有效(逻辑)输入、有效(逻辑)输出和变换中心部分;出和变换中心部分;3. 进行一级分解,设计模块结构的顶层和第进行一级分解,设计模块结构的顶层和第一层模块;一层模块;4. 进行二级分解,设计输入、输出和中心变进行二级分解,设计输入、输出和中心变换换部分的中、下层模块。部分的中、下层模块。软件工程软件工程94-94-49496:21:261. 1. 重画数据流图(平铺)重画数据流图(平铺)n为了建立系统结构,将数据流图平铺开来,为了建立系统结

41、构,将数据流图平铺开来,物理输入画在左侧,物理输出画在右侧。物理输入画在左侧,物理输出画在右侧。n如果一个外部实体既是物理输入又是物理输如果一个外部实体既是物理输入又是物理输出,则两侧都要画出它。出,则两侧都要画出它。ABBCEGGHDFCDEABCDEFGH物理输入物理输入物理输出物理输出软件工程软件工程94-94-50506:21:262. 2. 确定逻辑输入、逻辑输出确定逻辑输入、逻辑输出和变换中心部分和变换中心部分n变换中心是程序的核心功能,它的输入是逻变换中心是程序的核心功能,它的输入是逻辑输入,它的输出为逻辑输出。辑输入,它的输出为逻辑输出。变换中心变换中心ABBCEGGHDFCD

42、EABCDEFGH物理输入物理输入物理输出物理输出逻辑输入逻辑输入逻辑输出逻辑输出软件工程软件工程94-94-51516:21:263. 3. 第一级分解:第一级分解:设计模块结构的顶层和第一层设计模块结构的顶层和第一层n顶层模块:其功能就是整个系统的功能;顶层模块:其功能就是整个系统的功能;n输入控制模块:接收所有的输入数据;输入控制模块:接收所有的输入数据;n变换控制模块:实现输入到输出的变换;变换控制模块:实现输入到输出的变换;n输出控制模块:产生所有的输出数据。输出控制模块:产生所有的输出数据。顶层模块顶层模块变换控制变换控制输出控制输出控制输入控制输入控制软件工程软件工程94-94-

43、52526:21:26变换中心变换中心ABBCEGGHDFCDEABCDEFGH物理输入物理输入物理输出物理输出逻辑输入逻辑输入逻辑输出逻辑输出主模块主模块C D,E输入输入C输出输出D输出输出ECCD,EDE逻辑输入逻辑输入变换中心变换中心逻辑输出逻辑输出软件工程软件工程94-94-53536:21:264. 4. 第二级分解:设计中、下层模块第二级分解:设计中、下层模块输入控制模块的分解:从变换中心的边界开输入控制模块的分解:从变换中心的边界开始,沿着各输入通路,把输入通路上的每个始,沿着各输入通路,把输入通路上的每个加工映射成输入控制模块的一个低层模块。加工映射成输入控制模块的一个低层模

44、块。输出控制模块的分解:从变换中心的边界开输出控制模块的分解:从变换中心的边界开始,沿着各输出通路,把输出通路上的每个始,沿着各输出通路,把输出通路上的每个加工映射成输出控制模块的一个低层模块。加工映射成输出控制模块的一个低层模块。变换控制模块的分解:变换控制模块通常没变换控制模块的分解:变换控制模块通常没有通用的分解方法,应根据数据流图中变换有通用的分解方法,应根据数据流图中变换部分的实际情况进行设计。部分的实际情况进行设计。软件工程软件工程94-94-54546:21:26输出输出HG HABBCEGGHDFCD,EABCDEFGH物理输入物理输入物理输出物理输出主模块主模块CD,E输入输

45、入C输出输出D输出输出ECCD,EDE输入输入BBBCBC输入输入AABABA输出输出GE G输出输出FDFDFFEGGGHH软件工程软件工程94-94-55556:21:27输出输出HG HABBCEGGHDFCD,EABCDEFGH物理输入物理输入物理输出物理输出主模块主模块CD,E输入输入C输出输出D输出输出ECCD,EDE输入输入BBBCBC输入输入AABABA输出输出GE G输出输出FDFDFFEGGGHH软件工程软件工程94-94-56566:21:27事务分析事务分析n事务分析是从事务流型数据流图导出系统结事务分析是从事务流型数据流图导出系统结构图。构图。n步骤:步骤:1. 确定

46、事务中心和每条活动流的流特性确定事务中心和每条活动流的流特性 2. 将事务流型数据流图映射成高层的系统结将事务流型数据流图映射成高层的系统结构构3. 进一步分解进一步分解 软件工程软件工程94-94-57576:21:271. 1. 确定事务中心和各活动流的流特性确定事务中心和各活动流的流特性 n右图为事务流型右图为事务流型DFD的一般形式。的一般形式。n事务中心事务中心(图中的(图中的T):):位于活动流的起点,位于活动流的起点,活动流从该点成辐射状流出。活动流从该点成辐射状流出。n活动流:活动流:可为变换流可为变换流可为事务流可为事务流n事务流型的事务流型的DFD的组成:的组成:输入流事务

47、中心若干条活动流输入流事务中心若干条活动流 T T输入流输入流事务流事务流活动流活动流软件工程软件工程94-94-58586:21:27n右图为事务流型右图为事务流型DFD的高层结构形式。的高层结构形式。n顶层模块:其功能就是整个系统的功能。顶层模块:其功能就是整个系统的功能。n接收模块:接收输入数据。接收模块:接收输入数据。n分派模块:调度模块,分派模块:调度模块,控制下层的所有活动模块。控制下层的所有活动模块。n事务模块:对应活动流,事务模块:对应活动流,是该活动流映射成的。是该活动流映射成的。 2. 2. 将事务流型将事务流型DFDDFD映射成映射成高层系统结构高层系统结构顶层模块顶层模

48、块分派分派接收接收事务事务1 1事务事务2事务事务n软件工程软件工程94-94-59596:21:273. 3. 进一步分解进一步分解n接收模块:类同于变换分析中输入控制模块的接收模块:类同于变换分析中输入控制模块的分解。分解。n活动流模块:根据其流特性(变换流或事务流)活动流模块:根据其流特性(变换流或事务流)进一步采用变换分析或事务分析进行分解。进一步采用变换分析或事务分析进行分解。 软件工程软件工程94-94-60606:21:27模块设计的原则模块设计的原则n在选择模块设计的次序时,必须对一个模块在选择模块设计的次序时,必须对一个模块的全部直接下属模块都设计完成之后,才能的全部直接下属

49、模块都设计完成之后,才能转向另一个模块的下层模块的设计。转向另一个模块的下层模块的设计。n使用使用“黑盒黑盒”技术技术: 在设计当前模块时,在设计当前模块时,先把先把该模块的所有下层模块定义成该模块的所有下层模块定义成“黑盒黑盒”,在,在设计中利用它们时暂不考虑其内部结构和实设计中利用它们时暂不考虑其内部结构和实现。在这一步定义好的现。在这一步定义好的“黑盒黑盒”,在下一步,在下一步就可以对它们进行设计和加工。最后,全部就可以对它们进行设计和加工。最后,全部“黑盒黑盒”的内容和结构应完全被确定。的内容和结构应完全被确定。软件工程软件工程94-94-61616:21:27n在设计下层模块时,应考

50、虑模块的在设计下层模块时,应考虑模块的耦合耦合和和内内聚聚问题,以提高初始结构图质量。问题,以提高初始结构图质量。n模块划分时,一个模块的直接下属模块一般模块划分时,一个模块的直接下属模块一般在在 5 个左右。如果直接下属模块超过个左右。如果直接下属模块超过 10 个,个,可设立中间层次。可设立中间层次。n如果出现以下情况,就停止模块分解:如果出现以下情况,就停止模块分解: 模块不能再细分为明显的子任务;模块不能再细分为明显的子任务; 分解成用户提供的模块或库函数;分解成用户提供的模块或库函数; 模块接口是输入输出设备传送的信息;模块接口是输入输出设备传送的信息; 模块不宜再分解得过小。模块不

51、宜再分解得过小。软件工程软件工程94-94-62626:21:27n变换分析是软件系统结构设计的主要方法。变换分析是软件系统结构设计的主要方法。n一般,一个大型的软件系统是变换型结构和一般,一个大型的软件系统是变换型结构和事务型结构的混合结构。所以,我们通常利事务型结构的混合结构。所以,我们通常利用以变换分析为主,事务分析为辅的方式进用以变换分析为主,事务分析为辅的方式进行软件结构设计。行软件结构设计。软件工程软件工程94-94-63636:21:27abdpqrsbac1d分派模块分派模块事务控制事务控制qrs接受通路接受通路p软件工程软件工程94-94-64646:21:271.模块功能完

52、善化模块功能完善化 一个完整的模块应当有以下几部分:一个完整的模块应当有以下几部分: 执行规定的功能的部分;执行规定的功能的部分; 出错处理的部分。当模块不能完成规定的出错处理的部分。当模块不能完成规定的功能时,必须回送出错标志,出现例外情功能时,必须回送出错标志,出现例外情况的原因。况的原因。 如果需要返回数据给它的调用者,在完成如果需要返回数据给它的调用者,在完成数据加工或结束时,数据加工或结束时, 应当给它的调用者返应当给它的调用者返回一个状态码。回一个状态码。改进系统结构的启发式原则改进系统结构的启发式原则软件工程软件工程94-94-65656:21:272.消除重复功能,改善软件结构

53、消除重复功能,改善软件结构 完全相似完全相似:在结构上完全相似,可能只是:在结构上完全相似,可能只是在数据类型上不一致。此时可以采取完全在数据类型上不一致。此时可以采取完全合并的方法。合并的方法。 局部相似局部相似:找出其相同部分,分离出去,:找出其相同部分,分离出去,重新定义成一个独立的下一层模块。还可重新定义成一个独立的下一层模块。还可以与它的上级模块合并。以与它的上级模块合并。软件工程软件工程94-94-66666:21:27R1R2XYR1R2XYR1+R2XYX+R1Y+R2R1Y+R2X不可取不可取开关太多开关太多软件工程软件工程94-94-67676:21:273.模块的作用范围

54、应在控制范围之内模块的作用范围应在控制范围之内 模块的模块的控制范围控制范围包括它本身及其所有的从包括它本身及其所有的从属模块。属模块。 模块的模块的作用范围作用范围是指模块内一个判定的作是指模块内一个判定的作用范围,凡是受这个判定影响的所有模块用范围,凡是受这个判定影响的所有模块都属于这个判定的作用范围。都属于这个判定的作用范围。 如果一个判定的作用范围包含在这个判定如果一个判定的作用范围包含在这个判定所在模块的控制范围之内,则这种结构是所在模块的控制范围之内,则这种结构是简单的,否则,它的结构是不简单的。简单的,否则,它的结构是不简单的。软件工程软件工程94-94-68686:21:274

55、.尽可能减少高扇出结构尽可能减少高扇出结构如果一个模块的扇出数过大,就意味着该模如果一个模块的扇出数过大,就意味着该模块过分复杂,需要协调和控制过多的下属模块过分复杂,需要协调和控制过多的下属模块。应当适当增加中间层次的控制模块。块。应当适当增加中间层次的控制模块。PPP1P2软件工程软件工程94-94-69696:21:275.避免或减少使用病态联接避免或减少使用病态联接a. 直接病态联接直接病态联接b. 公共数据域病态联接公共数据域病态联接c.通信通信模块病态联接模块病态联接ABcommonABTABLEITABABxxxx(a) 直接病态联接直接病态联接(b) 公共数据域公共数据域 病态

56、联接病态联接(c) 通信模块通信模块 病态联接病态联接软件工程软件工程94-94-70706:21:276.模块的大小要适中。模块的大小要适中。7.设计功能可预测的模块设计功能可预测的模块 一个功能可预测的模块一个功能可预测的模块, 不论内部处理细节如不论内部处理细节如何,但对相同的输入数据,总能产生同样的何,但对相同的输入数据,总能产生同样的结果。但是,如果模块内部蕴藏有一些特殊结果。但是,如果模块内部蕴藏有一些特殊的鲜为人知的功能时,这个模块就可能是不的鲜为人知的功能时,这个模块就可能是不可预测的。对于这种模块,如果调用者不小可预测的。对于这种模块,如果调用者不小心使用,其结果将不可预测。

57、心使用,其结果将不可预测。软件工程软件工程94-94-71716:21:27保存当前标记保存当前标记恢复恢复“以前以前”标标记记标记?标记?标记?标记?功能不可预测的模块功能不可预测的模块软件工程软件工程94-94-72726:21:27n在过程设计阶段,要决定各个模块的实现算法,在过程设计阶段,要决定各个模块的实现算法,并精确地表达这些算法。并精确地表达这些算法。n对每个模块规定的功能以及算法的设计,给出对每个模块规定的功能以及算法的设计,给出适当的算法描述:适当的算法描述:v图形工具:程序流程图,图形工具:程序流程图, N-S ,PAD, HIPOv表格工具:判定表表格工具:判定表v语言工

58、具:语言工具: PDL , HIPO3.5 3.5 过程设计(详细设计)过程设计(详细设计)软件工程软件工程94-94-73736:21:27程序流程图程序流程图ABABPA1P=1A2=2An=nTSPFFSPT顺序型顺序型选择型选择型先判断先判断重复型重复型后判断后判断重复型重复型多分支选择型多分支选择型软件工程软件工程94-94-74746:21:27gabfx1x4x5x6x2x3入口入口hijcde出口出口流程图示例流程图示例FFFFFTTTTTswitchdo-whiledo-whilewhile-do=1=2=3软件工程软件工程94-94-75756:21:28N-S N-S 图

59、图ABPFTABPFTAwhile-do PAdo-while PAP= 1 = 2 = nA1 A2 An顺序型顺序型选择型选择型(1)选择型选择型(2)先判断重复型先判断重复型后判断重复型后判断重复型多分支选择型多分支选择型软件工程软件工程94-94-76766:21:28N-SN-S图(盒图)示例图(盒图)示例do-while x6abx1TTFFx2x4f=1=2=3gido-while x5hdec while-do x6j软件工程软件工程94-94-77776:21:28问题分析图问题分析图 (PAD)(PAD)S1SA1A2AnPPP=1=2=nwhile PSSS1S2S2un

60、til P选择型选择型顺序型顺序型多分支选择型多分支选择型先判断重复型先判断重复型后判断重复型后判断重复型软件工程软件工程94-94-78786:21:28PADPAD示例示例while-do x3bfgx1ado-while x6jx4do-while x5hicdex2=1=2=3软件工程软件工程94-94-79796:21:28PDL (Program Design Language)PDL (Program Design Language) PDL是一种用于描述功能模块的算法设计和加是一种用于描述功能模块的算法设计和加工细节的语言。称为设计程序用语言。它是一工细节的语言。称为设计程序用

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论