结构化设计概念和原理课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《结构化设计概念和原理课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 结构 设计 概念 原理 课件
- 资源描述:
-
1、第第 7 7 讲讲 设计概念与原理设计概念与原理内容提要内容提要软件设计的重要性、过程及其基本原则软件设计的重要性、过程及其基本原则设计的相关概念设计的相关概念模块化设计模块化设计模块设计的启发规则模块设计的启发规则概述概述软件设计软件设计:应用各种技术和原理,对一个软件系:应用各种技术和原理,对一个软件系统做出足够详细的决策,使之有可能在物理上得统做出足够详细的决策,使之有可能在物理上得以实现的过程。以实现的过程。软件软件设计设计是一个迭代的过程是一个迭代的过程。设计目标设计目标:将:将需求分析的结果需求分析的结果(分析模型与需求(分析模型与需求分析规约)转化为实际分析规约)转化为实际软件系
2、统的一个模型或软软件系统的一个模型或软件表达式件表达式,即用于构造软件的,即用于构造软件的“蓝图蓝图”。最终产品最终产品:设计规约,包括描述体系结构、数据、:设计规约,包括描述体系结构、数据、过程和界面设计模型。过程和界面设计模型。评审评审:清晰性、正确性、完整性。:清晰性、正确性、完整性。软件设计与程序设计不同。软件设计与程序设计不同。开发阶段的信息流开发阶段的信息流翻译需求模型到软件设计翻译需求模型到软件设计需求分析模型需求分析模型设计模型设计模型数据对象数据对象描述描述处理规格说明处理规格说明控制规格说明控制规格说明E-RDFDSTDDD过程设计过程设计接口设计接口设计体系结构设计体系结
3、构设计数据设计数据设计翻译分析模型到软件设计翻译分析模型到软件设计数据设计数据设计将分析时创建的信息域模型变换为软将分析时创建的信息域模型变换为软件所需的数据结构,件所需的数据结构,侧重于数据结构的定义侧重于数据结构的定义。体系结构设计体系结构设计定义软件系统各定义软件系统各主要结构构件之主要结构构件之间的关系。间的关系。过程设计过程设计则是把则是把结构构件结构构件转换成转换成软件的过程性软件的过程性描述描述。在编码步骤,根据这种过程性描述,生。在编码步骤,根据这种过程性描述,生成源程序代码,然后通过测试最终得到完整有成源程序代码,然后通过测试最终得到完整有效的软件。效的软件。接口设计接口设计
4、是建立软件内部的关系以及软件人是建立软件内部的关系以及软件人机之间的交互机制。机之间的交互机制。软件设计的重要性可以用软件设计的重要性可以用“质量质量”表达。表达。1 1. .软件设计的重要性软件设计的重要性软件设计软件设计是后续开发步骤及软件维护工是后续开发步骤及软件维护工作的基础。如果没有设计,只能建立一作的基础。如果没有设计,只能建立一个个不稳定的系统结构不稳定的系统结构。设计和软件质量设计和软件质量指导性原则指导性原则n设计应该展示一种设计应该展示一种层次性结构层次性结构。n设计应该设计应该模块化模块化。n设计应该包括设计应该包括数据数据、体系结构体系结构、接口接口和和模块模块(构件)
5、的清楚的表示。(构件)的清楚的表示。n设计应有性质不同的可区分的数据结构和过设计应有性质不同的可区分的数据结构和过程。程。n设计应该具有设计应该具有独立功能独立功能特征的模块。特征的模块。n设计应该设计应该降低降低模块和外部环境之间接口模块和外部环境之间接口的的复复杂性杂性。n设计应该利用需求分析中获得的信息和可重设计应该利用需求分析中获得的信息和可重复的方法。复的方法。2.2.设计过程设计过程从项目管理的角度来看,软件设计分两从项目管理的角度来看,软件设计分两步完成。步完成。n概要设计概要设计,将软件需求转化为数据结构和,将软件需求转化为数据结构和软件体系结构。软件体系结构。n详细设计详细设
6、计,即过程设计。通过对体系结构,即过程设计。通过对体系结构表示进行细化,得到软件的详细的数据结表示进行细化,得到软件的详细的数据结构和算法。构和算法。总体设计总体设计从回答从回答“做什么做什么”到回答到回答“怎样做怎样做”划分出组成系统的物理元素划分出组成系统的物理元素程序、程序、文件、数据库、过程和文档等等文件、数据库、过程和文档等等每个元素还是每个元素还是黑盒子黑盒子-“全局高度,抽象层次全局高度,抽象层次”3 3. .设计基本原理设计基本原理1.模块化:模块化:Modularityn模块模块是数据说明、可执行语句等程序对象的集是数据说明、可执行语句等程序对象的集合,是单独命名的并且可以通
7、过名字来访问,合,是单独命名的并且可以通过名字来访问,例如过程、函数、子程序、宏、例如过程、函数、子程序、宏、modula等。等。n软件被划分成独立命名和可独立访问的被称作软件被划分成独立命名和可独立访问的被称作模块的模块的构件构件,每个,每个构件构件完成一个子功能,它们完成一个子功能,它们集成到一起满足问题需求。集成到一起满足问题需求。easier to build, easier to change, easier to fix .模块化模块化模块化论据:模块化论据:C(x)C(x)定义为问题定义为问题x x的复杂性的复杂性E(x)E(x)定义为解决问题定义为解决问题x x所需要的工作量所
8、需要的工作量对对p1p1和和p2p2两个问题,两个问题, 若若 C(p1) C(p2)C(p1) C(p2),则则 E(p1) E(p2)E(p1) E(p2)C(p1 + p2) C(p1) + C(p2)C(p1 + p2) C(p1) + C(p2)E(p1 + p2) E(p1) + E(p2)E(p1 + p2) E(p1) + E(p2)不要过度模块化!每个模块的简单性将被集成不要过度模块化!每个模块的简单性将被集成的复杂性所掩盖。的复杂性所掩盖。模块化模块化模块化和软件成本模块化和软件成本n如何确定地预测最小成本区?如何确定地预测最小成本区?成本成本成本成本 / / 模块模块最小
9、成本区最小成本区接口成本接口成本软件总成本软件总成本模块数目模块数目模块化模块化如何确定模块的大小:如何确定模块的大小:n模块可分解性模块可分解性n模块可组装性模块可组装性n模块可理解性模块可理解性n模块的连续性模块的连续性n模块的可保护性模块的可保护性设计基本原理设计基本原理2.抽象抽象 Abstraction:n忽略细节,分层理解问题,自顶向下层层细化,包忽略细节,分层理解问题,自顶向下层层细化,包括对括对过程过程、数据数据和和控制控制的抽象。的抽象。n过程抽象过程抽象:一个命名的指令序列,具有特定和有限:一个命名的指令序列,具有特定和有限的的功能功能。n数据抽象数据抽象是命名的数据集合,
10、描述一个是命名的数据集合,描述一个数据对象数据对象。n控制抽象控制抽象隐含了不必说明的内部细节的程序控制机隐含了不必说明的内部细节的程序控制机制。制。n是实现模块化的手段之一。是实现模块化的手段之一。过程抽象过程抽象在这个抽象层次上,给出了在这个抽象层次上,给出了初步的过程初步的过程表示表示,所用的术语都已面向软件,而且,所用的术语都已面向软件,而且模块化的工作已经开始显露。模块化的工作已经开始显露。逐步细化和模块化的概念与抽象紧密相逐步细化和模块化的概念与抽象紧密相连。连。数据抽象数据抽象定义定义“绘图绘图 drawing”数据对象作为一种抽象数据类型数据对象作为一种抽象数据类型。nTYPE
11、 drawing IS STRUCTURE DEFINED number IS STRING LENGTH (12) geometry DEFINED notes IS STRING LENGTH (256) ENF drawing TYPE;nBlueprint IS INSTANCE OF drawing;nSchematic IS INSTANCE OF drawing;设计基本原理设计基本原理3.求精求精Refinementn自顶向下的设计策略。自顶向下的设计策略。doorimplemented as a data structuremanufacturermodel numberty
12、peswing directioninsertslights type numberweightopening mechanismopenimplemented with a knowledge of the object that is associated with enterdetails of enter algorithmwalk to door;reach for knob;Switch the knob;open door;walk through;close door.repeat until door opensturn knob clockwise;if knob does
13、nt turn, then take key out; find correct key; insert in lock;endifpull/push doormove out of way;end repeat求精求精设计的设计的求精求精过程与需求分析的划分类似,过程与需求分析的划分类似,只是考虑的细节层次不同。只是考虑的细节层次不同。求精求精实际是一个实际是一个详细描述详细描述的过程。的过程。抽象与抽象与求精求精是是互补互补的概念。的概念。设计基本原理设计基本原理4.信息隐藏信息隐藏 information hiding n信息隐藏:在设计和确定模块时,使得一个信息隐藏:在设计和确定模块时
14、,使得一个模块内包含的信息(过程和数据)对于模块内包含的信息(过程和数据)对于不需不需要这些信息的模块来说,是不可访问的要这些信息的模块来说,是不可访问的。n每个客户只能通过每个客户只能通过接口接口来了解该模块,而所来了解该模块,而所有的实现都隐藏起来。有的实现都隐藏起来。n隐藏就是有效的模块化可以通过定义一组独隐藏就是有效的模块化可以通过定义一组独立模块来实现。立模块来实现。信息隐藏信息隐藏a specific design decision“信息隐藏信息隐藏”,更准确地描述应是,更准确地描述应是“细节隐藏细节隐藏”,因为隐藏的,因为隐藏的不不是信息是信息,而是实现的细节而是实现的细节。4
15、4、模块化设计、模块化设计模块独立性模块独立性n度量标准:度量标准:内聚内聚 cohesion 和和耦合耦合 couplingn内聚是一个内聚是一个模块内部模块内部的交互程度;耦合是的交互程度;耦合是模块之间模块之间交互的程度。交互的程度。n好处:更有利于开发、设计好处:更有利于开发、设计/编码修改的副编码修改的副作用减小、模块的复用可能。作用减小、模块的复用可能。n功能独立性是良好设计的关键,设计又是功能独立性是良好设计的关键,设计又是软件质量的关键。软件质量的关键。耦合耦合(couple)是度量系统中模块之间的交互是度量系统中模块之间的交互程度。程度。Goal: 模块之间尽可能独立模块之间
16、尽可能独立耦合从低到高依次为:耦合从低到高依次为:非直接耦合非直接耦合(最好),(最好),数据耦合,数据耦合,标记耦合,控制耦合,外部耦合,公共耦合和内容耦合标记耦合,控制耦合,外部耦合,公共耦合和内容耦合(最差)(最差)。Great deal of dependenceIndependent Highly coupledLoosely coupledUncoupled 耦合耦合耦合耦合内容耦合内容耦合 content couplingn如果两个模块中的一个直接引用了另一个模如果两个模块中的一个直接引用了另一个模块的内容,则它们之间是内容耦合。块的内容,则它们之间是内容耦合。nOne modu
展开阅读全文