- 1、本文档共75页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C 完成第二级分解,设计输入、变换中心和输出部分的中、下层模块。 这一步主要是对上一步确定的软件结构进行逐层细化,为每一个输入、输出模块及变换模块设计下属模块。通常,一个输入模块应包括用于接收数据和转换数据(将接收的数据转换成下级模块所需的形式)的两个下属模块;一个输出模块应包括用于转换数据(将上级模块的处理结果转换成输出所需的形式)和传出数据的两个下属模块;变换模块的分解一般应根据变换中心的组成情况及模块分解的原则来确定下属模块。完成二级分解后,工资计算系统的软件结构如图4.13所示。 * 图4.13 完成二级分解后的工资计算系统软件结构 * (2)事务分析设计 图4.14 进行了边界划分的事务型数据流图 * A 划分边界,明确数据流图中的接收路径、事务中心和加工路径。 事务中心在数据流图中位于多条加工路径的起点,经过事务中心的数据流被分解为多个发散的数据流,根据这个特征很容易在图中找到系统的事务中心。向事务中心提供数据的路径是系统的接收路径,而从事务中心引出的所有路径都是系统的加工路径,如图4.14中对数据流图的划分。每条加工路径都具有自己的结构特征,可能为变换型,也可能为事务型。如图4.14中,路径1为变换型,路径2为事务型。 * B 建立事务型结构的上层模块。 事务型流图对应的软件结构的顶层只有一个由事务中心映射得到的总控模块;总控模块有两个下级模块,分别是由接收路径映射得到的接收模块和由全部加工路径映射得到的调度模块。接收模块负责接收系统处理所需的数据,调度模块负责控制下层的所有加工模块。两个模块共同构成了事务型软件结构的第一层。图4.14中,事务型数据流图映射得到的上层软件结构如图4.15所示。 * 图4.15 * C 分解、细化接收路径和加工路径,得到事务型结构的下层模块。 由于接收路径通常都具有变换型的特性,因此对事务型结构接收模块的分解方法与对变换型结构输入模块的分解方法相同。对加工路径的分解应按照每一条路径本身的结构特征,分别采用变换分析或事务分析方法进行分解。经过分解后得到的完整的事务型软件结构如图4.16所示。 * 图4.16 完整的事务型软件结构 * 3、面向对象的结构设计方法 具体方法参见10章面向对象的开发技术。 图4.17 典型的面向对象设计模型 * 4.5.3 软件结构设计说明书 软件结构设计说明书是结构设计阶段中最重要的技术文档,其主要内容应包括: (1) 引言:用于说明编写本说明书的目的、背景,定义所用到的术语和缩略语,以及列出文档中所引用的参考资料等。 (2) 总体设计:用于说明软件的需求规定、运行环境要求、处理流程及软件体系结构等。 (3) 运行设计:用于说明软件的运行模块组合、运行控制方式及运行时间等。 * (4) 模块设计:用于说明软件中各模块的功能、性能及接口等。 (5) 数据设计:用于说明软件系统所涉及的数据对象的逻辑数据结构的设计。 (6) 出错处理设计:用于说明软件系统可能出现的各种错误及可采取的处理措施。 * 4.7 小 结 软件设计是一个将软件需求转换为软件实现方案的过程,分为结构设计和详细设计两个阶段。结构设计阶段主要完成对系统宏观结构的设计,详细设计阶段则完成系统内部实现细节的确定。系统结构的设计应遵循相应的设计原则,特别是要保证模块的独立性。结构设计过程中通常采用结构图或HIPO图来描述软件的层次结构。 在面向数据流的结构设计方法中,将数据流图划分为变换型和事务型两种类型,对于不同类型的数据流图采用不同的映射方法获得系统的软件结构。 * (2) 保持适中的模块规模。 程序中模块的规模过大,会降低程序的可读性;而模块规模过小,势必会导致程序中的模块数目过多,增加接口的复杂性。对于模块的适当规模并没有严格的规定,但普遍的观点是模块中的语句数最好保持在10~100之间。为了使模块的规模适中,在保证模块独立性的前提下,可对程序中规模过小的模块进行合并或对规模过大的模块进行分解。 * (3) 模块应具有高扇入和适当的扇出 在模块调用中,某个模块的上级模块数被称为该模块的扇入(如图4.3(a)所示,模块M的扇入数为n);而某个模块可以调用的下级模块数被称为该模块的扇出(如图4.3(b)所示,模块M的扇出数为k)。显然,一个模块的扇入表明了共有多少个模块需要调用该模块,而其扇出表明了该模块可以控制的下级模块的数目。 * 图4.3 模块的扇入和扇出 (a) 扇入;(b) 扇出 * 模块的扇入越大,则说明共享该模块的上级模块数越多,或者说该模块在程序中的重用性越高,这正是程序设
文档评论(0)