面向对象的方法学导论.ppt

上传人:za****8 文档编号:15661266 上传时间:2020-08-28 格式:PPT 页数:50 大小:235.50KB
收藏 版权申诉 举报 下载
面向对象的方法学导论.ppt_第1页
第1页 / 共50页
面向对象的方法学导论.ppt_第2页
第2页 / 共50页
面向对象的方法学导论.ppt_第3页
第3页 / 共50页
资源描述:

《面向对象的方法学导论.ppt》由会员分享,可在线阅读,更多相关《面向对象的方法学导论.ppt(50页珍藏版)》请在装配图网上搜索。

1、Software Engineering,第6章面向对象的方法学导论,传统的软件工程方法学曾经给软件产业带来巨大进步,部分地缓解了软件危机,使用这种方法学开发的许多中、小规模软件项目都获得了成功。但是,人们也注意到当把这种方法学应用于大型软件产品的开发时,似乎很少取得成功。 在20世纪60年代后期出现的面向对象编程语言Simula_67中首次引入了类和对象的概念,自20世纪80年代中期起,人们开始注重面向对象分析和设计的研究,逐步形成了面向对象方法学。到了20世纪90年代,面向对象方法学已经成为人们在开发软件时首选的范型。面向对象技术已成为当前最好的软件开发技术。,Software Engin

2、eering,6.1 面向对象与传统结构化方法学比较,仔细分析可以发现,在现实世界中存在的对象是问题域中的主角,所谓对象是指客观存在的实体和主观抽象的概念,他是人类观察问题和解决问题的主要目标。例如,对于一个学校学生管理系统来说,无论是简单还是复杂,始终是围绕学生和老师这两个对象实施。在自然界,每个对象都具有一些属性和行为,例如学生有学号、姓名、性别等属性,已经上课、考试、做实验等行为。因此,每个个体都可以用属性和行为来描述。,Software Engineering,通常人类观察问题的视角是这些对象,对象的属性反应客体在某一时刻的状态,对象的行为反映客体多能从事的操作。这些操作附在对象之上并

3、能用来设置、改变和获取对象的状态。任何问题域都有一系列的对象,因此解决问题的基本方式是让这些对象之间相互驱动、相互作用,最终使每个对象按照设计者的意愿改变其属性状态。,6.1 面向对象与传统结构化方法学比较,Software Engineering,结构化设计方法所采用的设计思路不是将对象作为一个整体,而是将依附于对象之上的行为抽取出来,以功能为目标来设计构造应用系统。这种做法导致在进行程序设计的时候,不得不将对象所构成的现实世界映射到由功能模块组成的解空间中,这种变换过程,不仅增加了程序设计的复杂程度,而且背离了人们观察问题和解决问题的基本思路。另外,再仔细思考会发现,在任何一个问题域中,对

4、象是稳定的,而行为是不稳定的。,6.1 面向对象与传统结构化方法学比较,Software Engineering,6.2.1面向对象方法学的要点 面向对象(Object-Oriented,缩写为OO)方法学出发点和基本原则是,尽可能接近人类认识世界的方法和思维方式来解决问题。也就是使描述问题的问题空间(也称为问题域)与实现解法的解空间(也称为求解域)在结构上尽可能一致。,6.2 面向对象方法学概述,Software Engineering,面向对象方法有四个要点: 客观世界由各种对象组成,任何事物都是对象,复杂的对象可由简单的对象组合 把所有对象划分为各种对象类,每个类都定义了一组数据和一组方

5、法 继承:在定义和实现一个类的时候,可以在一个已经存在的类(父类)的基础上来进行,把这个已经存在的类所定义的内容做为自己的内容,并加入若干新内容。 继承是使用现存的定义作为基础,建立新定义的技术。和子类之间共享数据结构和方法的机制 对象彼此之间能通过传递消息互相通信,6.2.1面向对象方法学的要点,Software Engineering,OOA、OOD、OOP有机地集成在一起。 OOA(Object-Oriented Analysis) OOD(Object-Oriented Design) OOP(Object-Oriented Program) 一般说来,使用面向对象方法学开发软件时,工

6、作重点应该放在生命周期中的分析阶段,6.2.2面向对象的软件过程,Software Engineering,喷泉模型,是典型的面向对象的软件过程模型。 “喷泉”这个词体现了面向对象软件开发过程迭代和无缝的特性。,6.2.2面向对象的软件过程,Software Engineering,6.3 面向对象方法学的主要优点,1、与人类习惯的思维方法一致 面向对象的设计方法的基本原理是:使用现实世界的概念抽象地思考问题从而自然地解决问题。-它强调模拟现实世界中的概念而不强调算法 对象统一了数据与操作, 减少了出错的原因, 有利于数据与操作的协调。它鼓励开发者用应用领域的概念去思考。,Software E

7、ngineering,2、稳定性好 传统的软件开发方法以算法为核心,基于功能分析和功能分解。所建立起来的软件系统的结构紧密依赖于系统所要完成的功能,当功能需求发生变化时将引起软件结构的整体修改。而用户需求变化大部分是针对功能的,故这样的软件系统不稳定。对象模拟问题领域中的实体。面向对象的软件系统的结构是根据问题领域的实体模型建立起来的。现实世界中的实体是相对稳定的,对象为中心构造的软件系统也就比较稳定。,6.3 面向对象方法学的主要优点,Software Engineering,3、可重用性好 重用是提高生产率的最主要的方法。传统的软件重用技术是利用缺乏“柔性”的标准函数库,加之数据与处理的分

8、离,导致重用率低。面向对象方法统一了数据和操作,此外,对象固有的封装性和信息隐藏机制,使得对象的内部实现与外界隔离,具有较强的独立性。对象是较理想可重用的软件。继承性机制使得子类不仅可以重用其父类,而且可以对父类方便地修改和扩充而令对象具有灵活的“柔性”。,6.3 面向对象方法学的主要优点,Software Engineering,4、较易开发大型软件产品 把复杂庞大的软件分解为一系列相互独立的小产品(对象/类),不仅降低了开发工作的技术难度,而且也使得对开发工作的管理变得比较容易了。开发过程各阶段的 “无缝”连接,反复迭代的渐进性,都更利于对大型软件实施分而治之, 化整为零的策略.,6.3

9、面向对象方法学的主要优点,Software Engineering,5、可维护性好 (1) 面向对象的软件稳定性比较好。如前所述,当对软件的功能或性能的要求发生变化时,通常不会引起软件的整体变化,往往只需对局部作一些修改。由于对软件所需做的改动较小且限于局部,自然比较容易实现。(2) 面向对象的软件比较容易修改。类是独立性好的模块。如果不修改该类的对外接口,则可以完全不影响软件的其他部分。继承机制,使得对软件的修改和扩充比较容易实现。多态性机制,使得当扩充软件功能时对原有代码所需作的修改进一步减少。,6.3 面向对象方法学的主要优点,Software Engineering,(3) 面向对象的

10、软件比较容易理解。面向对象的软件技术符合人们习惯的思维方式,所建立的软件系统的结构与问题空间的结构基本一致。对象类有很强的独立性,当派生新类时候不需要了解其他类中的实现细节。因此,了解原有系统的工作量大幅度下降。 (4) 易于测试和调试。软件是否易于测试和调试,是影响软件可维护性的一个重要因素。类的独立性使对类的测试比较容易实现,如果发现错误也往往集中在类的内部,比较容易调试。,6.3 面向对象方法学的主要优点,Software Engineering,6.4 面向对象的概念,6.4.1 面向对象方法的基本概念 1、对象(Object)在应用领域中有意义的、与所要解决的问题有关系的任何事物都可

11、以作为对象(Object)。 对象可以是事、物、或抽象概念 ,是将一组数据和使用该数据的一组基本操作或过程封装在一起的实体。 它既可以是具体的物理实体的抽象,也可以是人为的概念,或者是任何有明确边界和意义的东西。例如,一名职工、一家公司、一个窗口、一座图书馆、一本图书、贷款和借款等,都可以作为一个对象。,Software Engineering,事物是行为的主体,任何事物都由状态和行为两个方面构成,状态反映了事物的内部结构,反映了事物的静态特性(即对象的属性),行为反映了事物的运动规律,反映了动态特性,故对象是事物状态和行为的数据抽象,既是事物状态的集合,也是为改变状态而施加的操作方法或算法程

12、序的集合。在OO法中的对象就是一个一个的可重用部件,是面向对象程序设计的基本元素。,6.4.1 面向对象方法的基本概念,Software Engineering,6.4.2 其他概念,1、 类(Class) 类又称对象类(Object Class),是一组具有相同属性和相同操作的对象的集合。在一个类中,每个对象都是类的实例(instance) 类与对象的关系如同一个模具与用这个模具铸造出来的铸件之间的关系。,Software Engineering,实例就是由某个特定的类所描述的一个具体的对象。,2、实例(Instance),属性:姓名 年龄 单位 职称 工资,状态:李伟 25 计算机系 讲师

13、 900,数 据 结 构,数 据 值,类:教师,对象:李伟,抽象 实例,6.4.2 其他概念,Software Engineering,3、消息(Message) 消息就是用来请求对象执行某个处理或回答某些信息的要求。 消息既可以是数据流,也可以是控制流。一条消息可以发送给不同的对象,对消息的解释完全由接收信息的对象来完成,不同的对象对相同形式的消息可以有不同的解释。,6.4.2 其他概念,Software Engineering,通常,一个消息由下述3部分组成: 接收消息的对象; 消息选择符(也称为消息名); 零个或多个变元。 在C+语言中应该向它发下列消息: MyCircle.Show(G

14、REEN); 其中MyCircle是接收消息的对象的名字,Show是消息选择符(即消息名),圆括号内的GREEN是消息的变元。当MyCircle接收到这个消息后,将执行在Circle类中所定义的Show操作。,6.4.2 其他概念,Software Engineering,4、方法(Method) 方法,是对象所能执行的操作。 C+中把方法称为成员函数,如Circle类中定义的成员函数Show(int color) 5、属性(Attribute) 属性,是类中定义的数据。 C+中把属性称为数据成员。 6、封装(encapsulation) 封装就是信息隐藏,通过封装对外界隐藏了对象的实现细节。

15、,6.4.2 其他概念,Software Engineering,7、继承(Inheritance),继承,是指能够直接获得已有的性质和特征,而不必重复定义它们。继承是子类自动地共享基类中定义的数据和方法的机制。,6.4.2 其他概念,Software Engineering,8、多态性(Polymorphism) 多态性:多态性(Polymorphism)是指相同的操作或函数,过程作用于不同的对象上并获得不同的结果。 即相同的操作的消息发送给不同的对象时,每个对象将根据自己所属类中所定义的操作去执行,故产生不同的结果。 例如: “绘图”操作,作用在“椭圆” 和“矩形” 上,,6.4.2 其他

16、概念,Software Engineering,9、重载(Overloading) 有两种重载: 1)函数重载 指在同一作用域内的若干个参数特征不同的函数可以使用相同的函数名字。 如: Show(int a, int b) Show(int x) Show(int x, int y, int z) C+语言中函数重载是通过静态联编实现的。即编译时根据函数变元的个数和类型,决定函数版本。,6.4.2 其他概念,Software Engineering,2)运算符重载 指同一运算符可以施加于不同类型的操作数上面。当被操作数类型不同时,运算符的含义是不同的。 编译时根据被操作数的类型,决定使用算符的

17、哪种语义。,6.4.2 其他概念,Software Engineering,6.5面向对象建模,为了更好地理解问题,人们常常采用建立问题模型的方法。所谓模型,就是为了理解事物而对事物作出的一种抽象,是对事物的一种无歧义的书面描述。通常,模型由一组图示符号和组织这些符号的规则组成,利用它们来定义和描述问题域中的术语和概念。更进一步讲,模型是一种思考工具,利用这种工具可以把知识规范地表示出来。 模型可以帮助我们思考问题、定义术语、在选择术语时作出适当的假设,并且可以帮助我们保持定义和假设的一致性。,Software Engineering,6.5面向对象建模,用面向对象方法开发软件,通常需要建立三

18、种形式的模型: 对象模型:描述系统数据结构 动态模型:描述系统控制结构 功能模型:描述系统功能 这3种模型从3个不同但又密切相关的角度模拟目标系统,它们各自从不同侧面反映了系统的实质性内容,综合起来则全面地反映了对目标系统的需求。3种模型必不可少,其重要程度不同,对象模型是最基本、最重要的。,Software Engineering,6.6对象模型,对象模型表示静态的、结构化的系统的“数据”性质。它是对模拟客观世界实体的对象以及对象彼此间的关系的映射,描述了系统的静态结构。 面向对象方法强调围绕对象而不是围绕功能来构造系统。在建立对象模型时,我们的目标是从客观世界中提炼出对具体应用有价值的概念

19、。 为了建立对象模型,需要定义一组图形符号,并且规定一组组织这些符号以表示特定语义的规则。也就是说,需要用适当的建模语言来表达模型,建模语言由记号(即模型中使用的符号)和使用记号的规则(语法、语义和语用)组成。通常,使用UML提供的类图来建立对象模型。,Software Engineering,6.6.1 表示类的符号,1. 定义类 UML中类的图形符号为长方形,用两条横线把长方形分成上、中、下3个区域(下面两个区域可省略),3个区域分别放类的名字、属性和服务,如图所示,Software Engineering,类名是一类对象的名字。命名是否恰当对系统的可理解性影响相当大,因此,为类命名时应该

20、遵守以下几条准则: (1) 使用标准术语。应该使用在应用领域中人们习惯的标准术语作为类名,不要随意创造名字。例如,“交通信号灯”比“信号单元”这个名字好, (2) 使用具有确切含义的名词。尽量使用能表示类的含义的日常用语作名字,不要使用空洞的或含义模糊的词作名字。例如“库房”比 “存物场所”确切。 (3) 必要时用名词短语作名字。为使名字的含义更准确,必要时用形容词加名词或其他形式的名词短语作名字。例如,“公司员工”等都是比较恰当的名字。,6.6.1 表示类的符号,Software Engineering,2. 定义属性 UML描述属性的语法格式: 可见性 属性名:类型名初值性质串 属性的可见

21、性(即可访问性)通常有下述3种:公有的(public)、私有的(private)和保护的(protected),分别用加号(+)、减号(-)和井号(#)表示。如果未声明可见性,则表示该属性的可见性尚未定义。 例:管理员:String=“未定” 类变量实例:货单数:Integer (类变量在该类所有对象中的属性值相等),6.6.1 表示类的符号,Software Engineering,3. 定义服务 服务也就是操作,UML描述操作的语法格式如下: 可见性 操作名(参数表): 返回值类型性质串 操作可见性的定义方法与属性相同。 参数表是用逗号分隔的形式参数的序列。描述一个参数的语法如下: 参数名

22、: 类型名=默认值 当操作的调用者未提供实在参数时,该参数就使用默认值。与属性类似,在类中也可定义类作用域操作,在类图中表示为带下划线的操作。这种操作只能存取本类的类作用域属性。,6.6.1 表示类的符号,Software Engineering,6.6.2 表示关系的符号,定义了类之后就可以定义类与类之间的各种关系了。类与类之间通常有关联、泛化(继承)、依赖和细化等4种关系。 1. 关联 关联表示两个类的对象之间存在某种语义上的联系。例如,作家使用计算机,我们就认为在作家和计算机之间存在某种语义连接,因此,在类图中应该在作家类和计算机类之间建立关联关系。,Software Engineeri

23、ng,(1) 普通关联 普通关联是最常见的关联关系,只要在类与类之间存在连接关系就可以用普通关联表示。普通关联的图示符号是连接两个类之间的直线,如图所示。,图 普通关联示例,6.6.2 表示关系的符号,Software Engineering,在表示关联的直线两端可以写上重数(multiplicity),它表示该类有多少个对象与对方的一个对象连接。 如果图中未明确标出关联的重数,则默认重数是1。 重数的表示方法通常有: 01 表示 0到1个对象; 0* 或* 表示 0到多个对象; 1+ 或1* 表示 1到多个对象; 115 表示 1到15个对象; 3 表示 3个对象。,6.6.2 表示关系的符

24、号,Software Engineering,(2) 聚集 聚集也称为聚合,是关联的特例。聚集表示类与类之间的关系是整体与部分的关系。在陈述需求时使用的“包含”、“组成”、“分为部分”等字句,往往意味着存在聚集关系。除了一般聚集之外,还有两种特殊的聚集关系,分别是共享聚集和组合聚集。 共享聚集 如果在聚集关系中处于部分方的对象可同时参与多个处于整体方对象的构成,则该聚集称为共享聚集。例如,一个课题组包含许多成员,每个成员又可以是另一个课题组的成员,则课题组和成员之间是共享聚集关系,,6.6.2 表示关系的符号,Software Engineering,组合聚集 如果部分类完全隶属于整体类,部分

25、与整体共存,整体不存在了部分也会随之消失(或失去存在价值了),则该聚集称为组合聚集(简称为组成)。例如,在屏幕上打开一个窗口,它就由文本框、列表框、按钮和菜单组成,一旦关闭了窗口,各个组成部分也同时消失,窗口和它的组成部分之间存在着组合聚集关系。,6.6.2 表示关系的符号,Software Engineering,2. 泛化 UML中的泛化关系就是通常所说的继承关系,它是通用元素和具体元素之间的一种分类关系。具体元素完全拥有通用元素的信息,并且还可以附加一些其他信息。,6.6.2 表示关系的符号,Software Engineering,3. 依赖和细化 (1) 依赖关系:其中一个模型元素是

26、独立的,另一个模型元素不是独立的,它依赖于独立的模型元素,如果独立的模型元素改变了,将影响依赖于它的模型元素。,6.6.2 表示关系的符号,Software Engineering,(2) 细化关系 当对同一个事物在不同抽象层次上描述时,这些描述之间具有细化关系。假设两个模型元素A和B描述同一个事物,它们的区别是抽象层次不同,如果B是在A的基础上的更详细的描述,则称B细化了A,或称A细化成了B。,6.6.2 表示关系的符号,Software Engineering,6.7 动态模型,动态模型表示瞬时的、行为化的系统的“控制”性质,它规定了对象模型中的对象的合法变化序列。动态模型着重于系统的逻辑

27、结构;描述某时刻对象及其联系的改变。包括状态图和事件追综图。 动态模型描述系统中各个操作发生的时序.,Software Engineering,1)事件:事件是某个特定时刻所发生的事情。它是引起对象状态转换的控制信息。 2)状态:状态就是对象在其生命周期中的某个特定阶段所处的某种情形。 3)行为:行为是指对象达到某种状态时所做的一系列处理操作。,6.7 动态模型,Software Engineering,实例: 电话的状态图,6.7 动态模型,Software Engineering,6.8 功能模型,功能模型表示变化的系统的“功能”性质,它指明了系统应该“做什么”,因此更直接地反映了用户对目

28、标系统的需求。通常,功能模型由一组数据流图组成。 UML提供的用例图也是进行需求分析和建立功能模型的强有力工具。在UML中把用用例图建立起来的系统模型称为用例模型。,Software Engineering,6.8 功能模型,Software Engineering,6.9 三种模型之间的关系,面向对象建模技术所建立的3种模型,分别从3个不同侧面描述了所要开发的系统。这3种模型相互补充、相互配合,使得我们对系统的认识更加全面:功能模型指明了系统应该“做什么”;动态模型明确规定了什么时候(即在何种状态下接受了什么事件的触发)做;对象模型则定义了做事情的实体。 在面向对象方法学中,对象模型是最基本

29、最重要的,它为其他两种模型奠定了基础,我们依靠对象模型完成3种模型的集成。下面扼要地叙述3种模型之间的关系。,Software Engineering,(1) 针对每个类建立的动态模型,描述了类实例的生命周期或运行周期。 (2) 状态转换驱使行为发生,这些行为在数据流图中被映射成处理,在用例图中被映射成用例,它们同时与类图中的服务相对应。 (3) 功能模型中的处理(或用例)对应于对象模型中的类所提供的服务。有时一个处理(或用例)对应多个服务,也有一个服务对应多个处理(或用例)的时候。,6.9 三种模型之间的关系,Software Engineering,(4) 数据流图中的数据存储,以及数据的源点/终点,通常是对象模型中的对象。 (5) 数据流图中的数据流,往往是对象模型中对象的属性值,也可能是整个对象。 (6) 用例图中的行为者,可能是对象模型中的对象。 (7) 功能模型中的处理(或用例)可能产生动态模型中的事件。 (8) 对象模型描述了数据流图中的数据流、数据存储以及数据源点/终点的结构。,6.9 三种模型之间的关系,Software Engineering,思考题,1.面向对象方法学的出发点和基本原则? 2.面向对象方法四个要点? 3.面向对象方法学的主要优点? 4.用面向对象方法开发软件,通常需要建立三种形式的模型?三种形式的模型之间的关系 ?,

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!