面向对象软件工程_第1页
面向对象软件工程_第2页
面向对象软件工程_第3页
面向对象软件工程_第4页
面向对象软件工程_第5页
已阅读5页,还剩45页未读 继续免费阅读

下载本文档

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

文档简介

面向对象软件工程第2章面向对象的软件工程教学提示:上一章介绍的是软件工程概论,主要介绍传统的软件工程。本章介绍现代的软件工程——面向对象的软件工程的内容。重点介绍面向对象的基本概念、要素以及面向对象方法的基本原理和步骤,为本教材后面将要学习的全程一体化建模工具PlayCASE奠定理论基础。教学目标:掌握关于面向对象的几个重要概念,包括对象、消息、方法、属性、继承性、封装性、多态性等;掌握面向对象软件工程的内容;了解面向对象方法的出发点、原则;了解面向对象的软件工程与传统的软件工程的差别,以及面向对象的软件工程中的三个模型和它们之间的关系。第2章面向对象的软件工程2.1引言2.2面向对象方法的基本思想2.3面向对象的基本概念与要素2.4三种形式的模型2.5面向对象的分析2.6面向对象的设计2.7面向对象的编程2.8面向对象的测试2.9面向对象的软件维护2.10习题2.1引言大量实践和研究表明,软件系统产生的错误有60%~80%都是需求定义不准确或错误导致的。造成需求定义不准确的主要原因是:在开发初期,用户缺乏计算机与信息系统方面的知识,常常难以清楚地给出所有需求,而开发人员缺乏用户方的业务知识,不易给出软件系统切合实际的描述。为了解决上述问题,除了从软件过程模型中寻找适当的模型而外,也可以从考虑问题的方法上着手,也就是说尽可能地使分析、设计和实现一个系统的方法接近认识一个系统的方法,接近认识客观世界的渐进过程,这就是面向对象方法研究的课题。2.2面向对象方法的基本思想面向对象方法是基于如下思想来认识世界的: 世界由对象构成; 对象有各自的内部状态和运动规律; 对象间联系和相互作用构成系统; 对象组织成系统从而构成世界; 追求解决问题的方法空间与客观世界问题结构空间一致。面向对象方法学的出发点和基本原则是:尽可能模拟人类所习惯的思维方式,使开发软件的方法和过程尽可能接近于人类认识世界解决问题的方法和过程,也就是使描述问题的问题域与实现解法的求解域在结构上尽可能地一致。2.3面向对象的基本概念与要素2.3.1面向对象的基本概念2.3.2面向对象的要素2.3.1面向对象的基本概念1.对象和类(1)对象::=〈ID,MS,DS,MI,〉

其中,ID是对象的标识或名字

MS是对象中的操作集合

DS是对象的数据结构

MI是对象受理的消息名集合(即对外接口)(2)类:是对具有相同数据和相同操作的一组相似对象的定义。2.3.1面向对象的基本概念2.状态/特征和属性

对象集合里的每一个对象都有相同/相似的状态,或着称为特征,把它抽象出来就是属性。因此,属性是一组状态值的集合,具有相同的结构和相同的值类型,而每一个状态就是属性的实例。从另一个角度来说,属性就是类中所定义的数据,它是对客观世界所具有的性质的抽象。类的每个实例都有自己特有的属性值。2.3.1面向对象的基本概念3.行为、操作和方法/服务方法或服务也是对行为或操作的抽象,是对象所能执行的操作,也可以说是一组行为或操作的集合,而每一个行为或操作都是方法或服务的实例。4.消息消息就是要求某个对象执行在定义它的那个类中所定义的某个操作的规格说明。通常,一个消息由下述三个部分组成:接收消息的对象;消息选择符(也称为消息名);零个或多个变元(即消息传递的参数)。2.3.2面向对象的要素1.继承性按照子类与父类的关系,把若干个对象类组成一个有层次结构的系统。在这种层次结构中,通常下层的派生类具有和上层的基类相同的特性(包括数据和方法),这种现象称为继承。继承是子类自动地共享父类中定义的数据和方法的机制。2.抽象为了记忆或区分,人类常常把客观世界的一些事物的基本特征、内在的属性概念化,用逻辑模型表达出来,这样的过程就是抽象。3.封装性一切从属于该对象的私有信息,都被封装在该对象类的定义中,就好像装在一个不透明的黑盒子中一样,在外界是看不见的,更不能直接使用,这就是“封装性”。2.3.2面向对象的要素4.共享性有三种共享类型。同一类中不同实例之间,它们有共同的数据结构、行为和属性结构,可能共享某一个值域空间的值,例如状态(数据成员值)或属性值。同一应用类层次结构的继承关系,共享父类/超类的结构或方法。同一应用的类是指类之间有关联的那些类。5.强调对象的结构它的含义是对象的结构在需求变化时变动较小,或者说对象的特征变化相对于功能变化即行为/操作的变化来说较小。行为/操作的变化影响的是单个方法的细节或接口等。对象的结构主要是指对象属性结构、数据结构和方法设计。2.3.2面向对象的要素6.多态性不同对象可以调用相同名称的方法(函数、过程)并可导致完成不同的行为。程序只需要进行一般形式的调用,方法的实现细节留给接受方法调用的对象。综上所述,面向对象的方法学可以用下列方程来概括:面向对象=对象+类+继承+消息也就是说,面向对象就是既使用对象又使用类和继承等机制,而且对象之间仅能通过传递消息实现彼此通信。2.4三种形式的模型2.4.1对象模型2.4.2动态模型2.4.3功能模型2.4.4三种模型的关系2.4.1对象模型

对象模型

定义了做事情的实体,描述系统的数据结构,包括对象之间的关系、对象的属性和操作,用对象图表示。2.4.2动态模型

动态模型

明确规定了什么时候做(即在何种状态下接受了什么事件的触发),描述系统的控制结构,即:描述类的对象的状态和事件的正确次序。2.4.3功能模型

功能模型

说明发生什么,它只关心系统做什么,而不考虑怎么做,描述系统的功能结构,用数据流程图DFD描述。2.4.4三种模型的关系

在面向对象方法学中,对象模型是最基本的、最重要的,它为其他两种模型奠定了基础,我们依靠对象模型完成三种模型的集成。

1.

针对每个类建立的动态模型,描述了类实例的生命周期或运行周期。

2.状态转换驱使行为发生,这些行为在数据流图中被映射成处理,它们同时与对象模型中的服务相对应。

3.功能模型中的处理,对应于对象模型中类-&-对象所提供的服务。

2.4.4三种模型的关系

4.功能模型中的数据存储,以及数据的源点/终点,通常是对象模型中的对象。

5.功能模型中的数据流,往往是对象模型中的属性值,也可能是整个对象。

6.功能模型中的处理可能产生动态模型中的事件。

7.对象模型描述了功能模型中的动作对象、数据存储以及数据流的结构。2.5面向对象的分析2.5.1面向对象分析的基本过程2.5.2标识对象2.5.3标识结构2.5.4标识主题2.5.5定义属性2.5.6定义服务大型系统的复杂问题对象模型由以下五个层次组成:①主题层:主题是控制读者在同一时间所能考虑的模型规模的机制。②对象层:对象是属性及其服务的抽象,反映系统保存有关信息和现实世界交互的能力。③结构层:结构表示问题空间的复杂度。④属性层:一个属性就是一个数据单元,用于描述一个对象或分类结构的实例。⑤服务层:服务是对象收到消息之后所执行的处理。

2.5.1面向对象分析的基本过程2.5.2标识对象参照常见事物找出在当前问题域中的候选对象。(1)可感知的物理实体(2)人或组织的角色(3)应该记忆的事件(4)两个或多个对象的相互作用(5)需要说明的概念非正式分析法 用自然语言书写的需求陈述为依据确定的候选者。

2.5.2标识对象筛选的主要依据冗余

无关

笼统

属性

操作实现单个实例派生结果

2.5.3标识结构1.分类结构 获得类—成员组织,用于刻画对象之间的层次关系,它通过搜集公共特性并把这种特性扩充至特例之中来显示现实世界事件的通用性及专用性。2.组装结构 刻画整体—部分组织,表达了自然的整体和部分的结构关系,从而把一些部分的聚合构造成整体。

2.5.3标识结构3.结构筛选己删去的类之间的结构。

与问题无关的或应在实现阶段考虑的结构关系。瞬时事件。三元结构关系。派生结构。

2.5.4标识主题主题提供了一个控制读者(分析员、管理者或客户)在一个时间内所能考虑和理解模型的多少部分的机制。主题同时也给出了OOA模型中各图的概观。将一幅单独的图上所显示的项(或者“图符”、“对象”)的数目限制在5~9之间。主题不超过7个。采用对图中符号进行分组的方法。

2.5.5定义属性几种常见情况:

(1)误把对象当做属性。

(2)把链属性误作为属性。

(3)把限定误当成属性。(如:最大年龄)(4)误把内部状态当成了属性。(5)过于细化。

(6)存在不一致的属性。

2.5.5定义属性定义属性步骤(1)标识属性;(2)属性定位;(3)标识和定义实例连接;(4)修订对象;(5)说明属性和实例连接约束。2.5.6定义服务服务 收到一条消息之后所执行的处理。

定义服务的中心问题 为每一个对象和分类结构定义所需要的行为。建立并维护对象实例的服务响应某事件的服务提供某种功能的服务定义服务的第二个问题 确定对象实例之间的必要的通信,即消息。 消息交互相当于语言中的祈使语句。

2.6面向对象的设计2.6.1设计准则2.6.2从分析到设计2.6.3设计内容2.6.1设计准则1.设计准则 模块化、低耦合、高内聚,还有多态性等准则。2.启发式规则:简单清晰、深度适当

单位客户个体客户客户演出公司单位2.6.2从分析到设计(1)适应变化的需求──问题域模型/框架修改;(2)对OOA的补充修改;(3)产品可用性──分离界面与面向对象分析,即可移植性;(4)多任务需要任务管理。分解任务简化并发行为的设计与编码,把并发的任务分离在多个处理机执行。

2.6.3设计内容

一、问题域部分:OOA向OOD的演进OOA向OOD的演进图问题域部分人机交互部分任务管理部分数据管理部分主题层类-&-对象层结构层属性层服务层面向对象分析模型对面向对象分析的扩充面向对象设计模型2.6.3设计内容二、人机交互部分人机接口部件的最基本对象是窗口,主要的窗口类型包括:①安全/登录窗口。②启动窗口。启动窗口主要完成:对象的创建和初始化;系统管理功能;外设的激活与关闭。③业务功能窗口。大多数面向对象的用户界面的设计都是事件驱动的。 GUI准则:

1.一致性

2.减少步骤

3.及时提供反馈信息

4.提供撤消命令

5.无须记忆

6.易学

7.富有吸引力2.6.3设计内容2.6.3设计内容三、任务管理部分确定必须同时动作的对象找出相互排斥的对象设计任务管理子系统:确定各类任务并把任务分配给适当的硬件或软件去执行

1.确定事件驱动型任务

2.确定时钟驱动型任务

3.确定优先任务

4.确定关键任务

5.确定协调任务2.6.3设计内容四、数据管理部分数据管理部件提供了在数据管理系统中存储和检索对象的基本结构。数据管理方法有:

1.关系数据库管理系统(RDBMS)2.面向对象数据库管理系统(OODBMS)2.6.3设计内容1.关系数据库管理系统(RDBMS)定义第三范式表:列出每个类的属性表,把属性表规范成第三范式,从而得出第三范式表的定义;为每个第三范式表定义一个数据库表;测量性能和需要的存储容量;修改先前设计的第三范式,以满足性能和存储需求。2.6.3设计内容2.面向对象数据库管理系统(OODBMS)两条途径:将关系型扩充成OODBMS:在传统的RDBMS的基础之上,增加抽象数据类型和继承性,以及一些一般用途的服务来创建操作类和对象。将面向对象编程语言(OOPL)扩充成OODBMS:在面向对象程序设计语言的基础之上,增加管理数据库中存储对象的语法和功能。2.7面向对象的编程2.7.1面向对象语言的选择2.7.2编程准则开发人员在编程之前,应选择一种最合适的面向对象语言,可以考虑以下一些实际因素:

1.将来能否占主导地位

2.可重用性

3.类库和开发环境

4.其他因素:培训服务、技术支持2.7.1面向对象语言的选择良好的编程风格有助于提高软件的可重用性、可扩充性和健壮性。以下准则值得注意:

1.提高类的内聚

2.减小类的规模

3.尽量不使用全局信息

4.封装实现策略

5.精心确定公有方法

6.预防用户的操作错误

7.检查参数的合法性

8.不要预先确定限制条件2.7.2编程准则2.8面向对象的测试2.8.1面向对象分析的测试2.8.2面向对象设计的测试2.8.3面向对象编程的测试2.8.4面向对象的单元测试2.8.5面向对象的集成测试2.8.6面向对象的系统测试2.8.1面向对象分析的测试传统的面向过程分析是一个功能分解的过程,是把一个系统看成可以分解的功能的集合。这种传统的功能分解分析法的着眼点在于研究一个系统需要什么样的信息处理方法和过程,以过程的抽象来对待系统的需要。而OOA则是“把E-R图和语义网络模型(即信息模型中的概念)与面向对象程序设计语言中的重要概念结合在一起而形成的分析方法”,最后通常是得到问题空间的图表的形式描述。2.8.2面向对象设计的测试建议针对功能的实现和重用以及对OOA结果的拓展,应从如下三方面考虑:(1)对认定的类的测试;(2)对构造的类层次结构的测试;(3)对类库的支持的测试。2.8.3面向对象编程的测试将测试的目光集中在:类功能的实现面向对象程序风格主要体现为以下两个方面(假设编程使用C++语言):数据成员是否满足数据封装的要求;类是否实现了要求的功能。2.8.4面向对象的单元测试传统的单元测试是针对程序的函数、过程或完成某一定功能

温馨提示

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

评论

0/150

提交评论