1、第一部分:基础篇,北京大学信息科学技术学院研究生课程 面向对象的分析与设计,主讲教师:邵维忠,2,课件说明这组课件是本人多年来在北京大学讲授“面向对象的分析与设计”课程时制作的,随着该领域理论与技术的发展而逐年改进。目前的最新版本所适应的教材是邵维忠、杨芙清合写的著作面向对象的分析与设计(清华大学出版社2013年1月)。为了促进学术交流和资源共享,现将这套课件无偿提供给国内讲授同类课程的教师和同行,欢迎他们在教学工作中使用或作为参考。课件共包括“基础篇”、“分析篇”和“设计篇”三部分,是按照54学时研究生课程制作的,各位教师可根据自己的授课对象及教学计划,对原课件进行剪裁或重新组织。北京大学信
2、息学院 邵维忠 电子信箱: 2013年7月2日,3,从程序设计方法的角度看,面向对象是一种新的程序设计范型(paradigm),其基本思想是使用对象、类、继承、封装、聚合、关联、消息、多态性等基本概念来进行程序设计。,自20世纪80年代以来,面向对象方法已深入到计算机软件领域的几乎所有分支。它不仅是一些具体的软件开发技术与策略,而且是一整套关于如何看待软件系统与现实世界的关系,用什么观点来研究问题并进行问题求解,以及如何进行系统构造的软件方法学。从这个意义上讲:,面向对象方法是一种运用对象、类、继承、封装、聚合、关联、消息、多态性等概念来构造系统的软件开发方法。,1.1 什么是面向对象,第1章
3、 面向对象方法概论,4,面向对象方法的基本思想,一、从现实世界中客观存在的事物出发来构造系统 强调直接以问题域(现实世界)中的事物为中心来思考问题、认识问题,并根据这些事物的本质特征,把它们抽象为系统中的对象,作为系统的基本构成单位。这可以使系统直接映射问题域,保持问题域中事物及其相互关系的本来面貌。,二、充分运用人类日常的思维方法 强调运用人类在日常的逻辑思维中经常采用的思想方法与原则,例如抽象、分类、继承、聚合、封装、关联等等。这使得软件开发者能更有效地思考问题,并以其他人也能看得懂的方式把自己的认识表达出来。,5,主要特点:,用类和对象作为系统的基本构成单位。对象对应问题域中的事物,其属
4、性和操作刻画了事物的静态特征和动态特征,它们之间的继承关系、聚合关系、关联和消息如实地表达了问题域中事物之间实际存在的各种关系。 因此,无论系统的构成成分,还是通过这些成分之间的关系而体现的系统结构,都可直接地映射问题域。,6,对问题域的认识(人),客观世界 (问题域),计算机,自然语言,语 言 的 鸿 沟,编程语言,语言的过渡(人),编程(人),程序的理解 和执行(机器),软件开发:对事物的认识和描述问题语言的鸿沟,1.2 从认识论看面向对象方法的形成,7,计算机,自然语言,客观世界 (问题域),语言的鸿沟,语言的发展鸿沟变窄,程序的指令、数据、地址,都是由二进制的“0”和“1”构成的。离机
5、器最近,能够直接地执行,然而没有丝毫形象的意义,离人类的思维最远。,8,问题域,测试,编程,计算机,编程语言,自然语言,需求 分析,总体 设计,详细 设计,软件工程学的作用 传统的软件工程方法,9,问题域,OOA,计算机,自然语言,面向对象 编程语言,OOD,OOP,OOT,软件工程学的作用 面向对象的软件工程方法,10,1.3 面向对象方法的基本概念与原则,对象,类 属性,操作 封装 继承,一般-特殊结构 聚合,整体-部分结构 关联 消息 多态 持久对象,主动对象 ,11,对象是现实世界中某个实际存在的事物,它可以是有形的,比如一辆汽车,也可以是无形的,比如一项计划。对象是构成世界的一个独立
6、单位。它具有自己的静态特征和动态特征。,属性是用来描述对象静态特征的一个数据项。 操作是用来描述对象动态特征的一个动作序列。 对象标识就是对象的名字,有“外部标识”和“内部标识”之分。,对象,属性,操作,12,封装:把对象的属性和操作结合成一个独立的系统单位,并尽可能隐蔽对象的内部细节。,封装的重要意义: 使对象能够集中而完整地描述并对应一个具体的事物。 体现了事物的相对独立性,使对象外部不能随意存取对象的内部数据,避免了外部错误对它的“交叉感染”。 对象的内部的修改对外部的影响很小,减少了修改引起的“波动效应”。,封装带来的问题: 编程的麻烦 执行效率的损失解决办法: 不强调严格封装, 实行
7、可见性控制。 (混合型OOPL)例如: C+,13,抽象,类,一般类,特殊类,抽象与分类:忽略事物的非本质特征,只注意那些与当前目标有关的本质特征,从而找出事物的共性,叫做抽象。抽象是形成概念的基本手段。把具有共同性质的事物划分为一类,叫做分类。,类是具有相同属性和操作的一组对象的集合,它为属于该类的全部对象提供了统一的抽象描述,其内部包括属性和操作两个主要部分。类的作用是用来创建对象,对象是类的一个实例。,14,不同程度的抽象可得到不同层次的分类,较多地忽略事物之间的差别可得到较一般的类,较多地注意事物之间的差别可得到较特殊的类,运输工具,火车,汽车,飞机,卡车,轿车,轮船,车辆,15,定义
8、1:如果类A具有类B的全部属性和全部操作,而且具有自己特有的某些属性或操作,则A叫做B的特殊类,B叫做A的一般类。一般类与特殊类又称父类与子类。,定义2:如果类A的全部对象都是类B的对象,而且类B中存在不属于类A的对象,则A是B的特殊类,B是A的一般类。可以证明,以上两种定义是等价的,一般类和特殊类的定义,16,继承:,特殊类拥有其一般类的全部属性与操作,称作特殊类对一般类的继承。,继承意味着自动地拥有,或曰隐含地复制,继承简化了人们对事物的认识和描述,非常有益于软件复用,是OO技术提高软件开发效率的重要原因之一。,由继承机制保证,由一组具有继承关系的类所组成的结构称作一般-特殊结构。它是一个
9、以类为结点,以继承关系为边的连通的有向图。,继承关系的语义:“is a kind of”,17,多继承:允许一个特殊类具有一个以上一般类的继承方式称作多继承,18,聚合:,是两个类之间的一个二元关系,它表示一个类的对象实例以另一个类的对象实例作为其组成部分。 聚合刻画了现实事物之间的构成关系或者拥有关系。,聚合关系的语义:“has a”或“is a part of”,紧密、固定的聚合方式又称为组合,19,整体-部分结构:,聚合关系又称整体-部分关系。由一组具有聚合关系的类所形成的结构称为整体-部分结构。它是一个以类为结点,以聚合关系为边的连通有向图。,20,关联:,两个或者多个类上的一个关系(
10、即这些类的对象实例集合的笛卡儿积的一个子集合),其中的元素提供了被开发系统的应用领域中一组有意义的信息。,21,用集合论的观点和系统需求讨论关联概念,关联是两个或者多个类上的一个关系,其中的元素提供了被开发系统的应用领域中一组有意义的信息。,例:设A和B是两个类,它们的对象实例集合是A=a1,a2,an B=b1,b2,bm,A和B的笛卡儿积AB= , , , , , , ,这个笛卡儿积集合中有n m个元素,它们可以组合成2( n m)个子集合。 但是只有某个子集合中的元素提供了被开发系统的应用领域中一组有意义的信息时,才有必要把它定义为系统中的一个关联。,22,例如:在一个教学管理系统中 有
11、教师、学生、教务员课程等类。系统中需要表明每一门课程由哪位教师承担、有哪些学生选修,因此需要在教师和课程之间定义一个关联,在学生和课程之间也定义一个关联。该系统的教务员要为学生做注册、登记成绩等工作,但是不需要区别是哪个教务员为哪个学生做的,因此就不需要在教务员和学生这两个类之间定义关联。,教师,课程,学生,1,*,*,*,教务员,23,消息:消息是向对象发出的服务请求,目前在大部分面向对象的编程语言中,消息其实就是函数(或过程)调用。,但是,函数调用只是实现消息的方式之一,上述理解只适合于顺序系统,更一般的定义: 消息是对象之间在一次交互中所传送的信息,24,教师,课程,学生,1,*,*,*
12、,纠正一种误解认为在任何两个类之间只有存在关联才可能存在消息。实际上,关联和消息是两个截然不同的概念,二者是相互独立的。,教务员,call,25,多态:,多态是指同一个命名可具有不同的语义。OO方法中,常指在一般类中定义的属性或操作被特殊类继承之后,可以具有不同的数据类型或表现出不同的行为。,实现机制: 重写(override)在特殊类中对继承来的属性或操作重新定义其实现; 动态绑定(dynamic binding)在运行时根据对象接收的消息动态地确定要连接哪一段操作代码; 类属(generic)操作参量的类型可以是参数化的。,26,其他:,持久对象: 在程序运行结束后仍能继续保存的对象超出了
13、程序运行时间,跨越了内外存空间实现途径:支持持久对象的OOPL,OO-DBMS,主动对象: 至少有一个操作不需要接收消息就能主动执行的对象。 描述具有主动行为的事物 描述并发执行的多个控制流,27,面向机器 面向代数 面向过程 面向数据 面向人 面向文件 面向信息 面向应用 面向功能 面向数据流,面向对象是软件方法学的返朴归真,软件科学的发展历程中出现过许多“面向”,软件开发从过分专业化的方法、规则和技巧中回到了客观世界,回到了人们的日常思维,是软件理论的返朴归真。,面向对象,28,1. 雏形阶段60年代挪威计算中心开发的Simula67面向对象语言的先驱和第一个里程碑(首先引入了类的概念和继
14、承机制)。70年代CLU、并发Pascal、Ada和Modula-2等语言对抽象数据类型理论的发展起到重要作用(支持数据与操作的封装)。犹他大学的博士生Alan Kay设计了一个实验性的语言Flex。从Simula 67中借鉴了许多概念,如类、对象、继承等。1972年Palo Alno研究中心(PARC)发布了Smalltalk-72,其中正式使用了“面向对象”这个术语。Smalltalk的问世标志着面向对象程序设计方法的正式形成。但是这个时期的Smalltalk语言还不够完善,1.4 OO方法的发展历史与现状,29,PARC先后发布了Smalltalk-72,76,78等版本,直至1981年
15、推出该语言最完善的版本Smalltalk-80。Smalltalk-80的问世被今认为是面向对象语言发展史上最重要的里程碑。迄今绝大部分面向对象的基本概念及其支持机制在Smalltalk-80中都已具备。它是第一个完善的、能够实际应用的面向对象语言。但是,Smalltalk开始几年的应用不够广泛,原因是: 一种新的软件方法学被广泛接受需要一定的时间。 商品化软件开发工作到87年才开始进行。 追求纯OO的宗旨使许多软件开发人员感到不便。,2.完善阶段,30,3.繁荣阶段自80年代中期到90年代,是面向对象语言走向繁荣的阶段。其主要表现是大批比较实用的OOPL的涌现,例如 C+、Objective
16、-C、Object Pascal、CLOS(Common Lisp Object System)、Eiffel、Actor等。OO编程语言分为纯OO语言和混合型OO语言混合型语言是在传统的过程式语言基础上增加OO语言成分,在实用性方面具有更大的优势。此时的纯OO语言也比较重视实用性。,31,4、发展到软件生存周期前期阶段,计算机软件领域的很多新的方法与技术都有这样的发展经历,例如:结构化方法,形式化方法,软件复用。 与其他方法相比,面向对象的方法与技术发展到软件生命期的前期阶段有着更为深刻的意义。,面向对象方法从编程发展到设计、分析,进而发展到整个软件生存周期。,32,5. 最新发展编程语言
17、语言 + 类库 + 可视化编程环境例如: Visual C+, Visual Basic, Delhpi分析与设计方法 走向统一,形成统一建模语言UML 结束各种方法的概念及表示法不一致的局面,33,在软件生存周期全过程运用面向对象方法,L.M.Northrop:“尽管面向对象语言正取得令人振奋的发展,但编程并不是软件开发问题的主要根源。需求分析与设计问题更为普遍并且更值得解决。因此面向对象开发技术的焦点不应该只对准编程阶段,而应更全面地对准软件工程的其他阶段。面向对象方法真正意义深远的目标是它适合于解决分析与设计期间的复杂性并实现分析与设计的复用。面向对象的开发不仅仅是编程,必须在整个软件生
18、存周期采用一种全新的方法,这一观点已被人们所接受。 软件工程百科全书纽约,1994,34,第2章 不同的分析与设计方法,几种典型的 建模方法功能分解法 结构化方法 信息建模法 面向对象方法,本章内容结构,35,历史上几种典型的建模方法,2.1 功能分解法 (function decomposition)以系统需要提供的功能为中心来组织系统。 首先定义各种功能,然后把功能分解为子功能 对较大的子功能进一步分解,直到可给出明确的定义。 根据功能子功能的需要设计数据结构。 定义功能/子功能之间的接口。没有明确地区分分析与设计,建模过程: 层层进行功能分解,36,功能 模块,功能 模块,功能 模块,功
19、能 模块,功能 模块,功能 模块,功能 模块,功能 模块,功能 模块,功能 模块,得到的系统模型: 由模块及其接口构成,优点与缺点:直接地反映用户的需求,所以工作很容易开始。不能直接地映射问题域,很难检验结果的正确性。对需求变化的适应能力很差。局部的错误和修改很容易产生全局性的影响。,37,2.2 结构化方法 结构化分析(structured analysis,SA) 结构化设计(structured design,SD),结构化分析又称数据流法,其基本策略是跟踪数据流,即研究问题域中数据如何流动,以及在各个环节上进行何种处理,从而发现数据流和加工。得到的分析模型是数据流图(DFD),主要模型
20、元素是数据流、加工、文件及端点,外加处理说明和数据字典。,结构化设计与功能分解法基本相同,基于模块的概念建立设计模型,分为概要设计和详细设计。 概要设计:确定系统中包含哪些模块以及模块之间的调用关系,得到模块结构图(MSD)。 详细设计:描述每个模块内部的数据结构和操作流程。,38,数据流,加工,文件,起点,处理说明 ,数据词典 ,优点: 有严格的法则,强调研究问题域。缺点: 仍然是间接映射问题域; 与结构化设计的概念不一致,从分析到设计的过渡比较困难; 数据流和加工的数量太多,引起分析文档的膨胀。,终点,39,2.3 信息建模法(information modeling)由实体-关系法(E-
21、R方法)发展而来。 核心概念是实体和关系。实体描述问题域中的事物,关系描述事物之间在数据方面的联系,都可以带有属性。 发展之后的方法也把实体称作对象,并使用了类型和子类型的概念,作为实体(对象)的抽象描述。,有人也称之为面向对象方法,但有以下差别: 1.强调的重点是信息建模和状态建模,而不是对象建模。 2.没有把对实体属性所进行的操作封装到实体对象中。 3.只有属性的继承,不支持操作的继承。 4.没有采用消息通讯。,实体,属性,属性,属性,属性,关系,实体,m,n,E-R 图,信息模型,m,n,对象属性,关系属性,对象属性,40,2.4 面向对象方法面向对象的分析(OOA) 面向对象的设计(O
22、OD)运用对象、类、继承、封装、聚合、关联、消息、多态性等概念来构造系统。把问题域中的事物抽象为对象,作为系统的基本构成单位其属性和操作刻画了事物的静态特征和动态特征完整地刻画了问题域中事物。用类作为对象的抽象描述,建立它们之间的继承、聚合、关联、消息等关系如实地表达了问题域中事物之间的各种关系。封装、继承、聚合、关联、消息通讯等原则符合人类的日常思维使系统的复杂性得到控制。因此,得到的系统模型可以直接映射问题域。,41,不同的建模方法 体现于 从不同的概念出发来认识问题域 用不同的概念进行系统构造 系统对现实世界的不同映射,42,审批,不同的方法对同一应用实例(电话安装业务系统)的不同效果结
23、构化分析数据流和加工,登记,安装,开通,问题: 不是直接映射问题域,与问题域事物相关的数据和操作不是围绕这些事物来组织的,而是分散在数据流和加工中; 经常发生信息膨胀模型中的多个数据流,实现中其实只是一项数据; 分析模型难以与设计模型及源程序对应。,用户登记表,用户登记表,用户登记表,用户登记表,文件,用户信息,43,面向对象方法对象及其关系,用户登记表用户名 登记人 审批人 施工队 号码登记 审批 安装 开通,用户,营业员,主管人,施工队,机房,1,*,1,*,1,*,call,call,call,call,直接映射了问题域中的实际事物; 能够与程序形成良好的对应。,44,顾名思义,面向对象
24、的分析(OOA),就是运用面向对象方法进行系统分析。首先,OOA是分析,是软件生存周期的一个阶段,具有一般分析方法共同具有的内容、目标及策略; 但是,它强调运用面向对象方法进行分析,用面向对象的概念和表示法表达分析结果。基本任务:运用面向对象的概念对问题域进行分析和理解,将问题域中与系统责任有关的事物抽象为系统中的类和对象,定义这些类和对象的属性与操作,以及它们之间所形成的各种关系。最终目标:建立一个满足用户需求、直接映射问题域的OOA模型及其规约。,2.4.1 什么是OOA,问题: OOA是需求分析还是系统分析?,45,2.4.2 什么是OOD 不同时期有不同内容及特点,早期(80年代末期之
25、前)OOD的特点:1、不是基于OOA的 大多基于结构化分析结果(数据流图)2、是OO编程方法的延伸 多数方法与编程语言有关,特别受Ada影响很大3、不是纯OO的 对某些OO概念(如继承)缺少支持, 搀杂一些非OO 概念(如数据流、包、模块等)4、不是只针对软件生存周期的设计阶段 OOD中的“D”指的是Design 或 Development 多少涉及分析问题(如识别问题域的对象),但很不彻底早期的OOD可看作现今OOA&D方法的雏形,46,定义:面向对象的设计(OOD)就在是OOA模型基础上运用面向对象方法进行系统设计,目标是产生一个符合具体实现条件的OOD模型。,现今(90年代以后)OOD的
26、特点:1. 以面向对象的分析为基础,一般不依赖结构化分析。2. 与相应的OOA方法共同构成一种OOA&D方法体系。OOA和OOD采用一致的概念与原则,但属于软件生存周期的不同阶段,有不同的目标及策略。3. 较全面地体现面向对象方法的概念与原则。4. 大多数方法独立于编程语言,通过面向对象的分析与设计所得到的系统模型可以由不同的编程语言实现。,47,软件建模面临的挑战,1、问题域和系统责任复杂性日益增长问题域(problem domain):被开发系统的应用领域,即在现实世界中由这个系统进行处理的业务范围。 系统责任(system responsibilities):所开发的系统应该具备的职能。
27、 随着硬件性能的提高和价格的下降,软件系统所面临的问题域和系统责任越来越复杂,因此系统也越来越庞大。,2、交流问题软件系统的开发需要各类人员之间频繁交流。领域的多样性使软件工程中的交流问题比与其他工程更为突出。 有效的交流需要一种彼此都能理解的共同语言,否则将使彼此的思想难以沟通,很容易隐藏下许多错误。,2.4.3 OO方法的主要优点,48,3、需求的不断变化用户因素,竞争因素,经费因素开发者必须接受和适应需求变化,易变部分和稳定部分: 功能:最易变 外部接口:很易变 属性:较易变 对象:较稳定,4、软件复用的要求复用级别提高分析结果复用 要求分析模型的基本成分可以在多个系统中复用 要求一个分
28、析模型可以在多种条件下设计和实现,需求 变化,系统局部修改,受影响 部分修改,产生 新错误,延长开发时间,49,面向对象方法的优势,对问题域和系统责任的复杂性具有较强的处理能力 从问题域中的实际事物出发来构造系统模型,使系统模型能直接地映射问题域;继承、封装、聚合等概念使系统的复杂性得到有效的控制。 提供了便于各类相关人员交流共同语言 使用与问题域一致的概念及术语,体现人类的日常思维方式,为改进各类人员之间的交流提供了最基本的条件。 对需求的变化具有较强的适应性 按封装原则把系统中最容易变化的因素隔离起来,系统的各个单元成分之间接口很少,把需求变化所引起的影响局部化。 为实现分析与设计级别的软
29、件复用提供了有力支持 OO方法的封装、继承、聚合等原则,对象的完整性、独立性以及与问题域的良好对应,使之非常有利于软件复用。贯穿软件生存周期全过程的一致性 从OOA开始使用与问题域一致的概念、词汇、原则及表示法,这种一致性保持到设计、编程、测试、维护等各个阶段,对于整个软件生存周期的开发、维护及管理活动都具有重要的意义。,50,Booch方法 Coad-Yourdon方法 Firesmith方法 Jacobson方法(OOSE)Martin-Odell方法 Rumbaugh方法(OMT) Seidewitz-Stark方法 Shlaer-Mellor方法 Wirfs-Brock方法 ,2.4.
30、4 几种典型的OO方法,方法的异同体现于:概念 表示法 系统模型 开发过程 可用性 技术支持,51,Booch方法,必要时使用,用于分析和设计,6种模型图,基本图,通常不可缺少,类图对象图模块图进程图,只用于设计,补充图,状态转移图交互图,模型图,52,开发期望行为 模型(分析),建立体系结构 (设计),逐渐形成实现 (演化),建立核心需求 (概念化),(a) 宏过程,识别类 和对象,识别类和 对象的语义,识别类和 对象的关系,说明类和对象 的接口和实现,(b) 微过程,管理交付后的 演化(维护),特点: 思想活跃,开拓与创新 可操作性不够强 类图与对象图并存,过程,Booch方法(续),53
31、,主题层 类及对象层 结构层 属性层 服务层,OOA模型的5个层次,主题层 类及对象层 结构层 属性层 服务层,人机交互 部分 (HIC),问题域 部分 (PDC),任务管理 部分 (TMC),数据管理 部分 (DMC),OOD模型的5个层次和4个部分,Coad/Yourdon方法,特点: 概念简练,过程清晰 强调概念的一致性 过程指导不够具体,54,实体对象,界面对象,控制对象,三种对象,行为,表示,信息,三维的分析模型 四维的设计模型,实现环境,需求说明,需求分析,健壮分析,需求模型,分析模型,需求模型,设计,实现,设计模型,实现模型,分析模型,需求模型,单元测试,组装测试,实现模型,设计
32、 模型,系统测试,测试模型,分析过程,构造过程,测试过程,Jacobson方法(OOSE),特点: 通过用况描述用户需求 用交互图描述对象之间的交互 用况驱动的观点言之有过,55,三个模型,Rumbaugh方法(OMT),过程: 分析(面向对象) 系统设计(传统方法) 对象设计(面向对象) 实现,特点: 概念严谨,阐述清楚 过程具体,可操作性强 包含了许多非OO的内容 提出若干扩充概念,偏于复杂,56,第3章 统一建模语言UML简介,3.1 UML的背景与发展历史3.2 UML1概况3.3 UML2概况,主要组成部分 元模型体系结构 具体元类和抽象元类 各种图和扩展机制,UML2的四个规范 图
33、的增加和主要变化,57,面向对象方法种类繁多 1989年约10种,1994年达到50种以上 概念、表示法、过程策略及文档组织等方面的差异 使用户在选择建模方法和工具时无所适从 不利于技术交流迫切需要OO概念及表示法走向统一和标准化 统一建模语言UML应运而生,诞生背景,UML的背景与发展历史,58,发展历史第一阶段:OO方法学家的联合行动 1995.10: G. Booch与J. Rumbaugh联合 推出Unified Method 0.8 1996.6: I. Jacobson加入 推出UML 0.9(Unified Modeling Language),不再称“方法”而改称“建模语言”,
34、第二阶段:公司的联合行动 1996:成立了UML伙伴组织,12家公司加入 1997.1:推出UML1.0,另外5家公司加盟 1997.9:形成UML1.1,提交OMG作为建模语言规范提案 1997.11: UML1.1被OMG正式采纳,59,第三阶段:OMG主持下的修订 19972002:OMG成立UML修订任务组主持UML的修订 先后产生UML1.2、UML1.3、 UML1.4、 UML1.5等版本,UML1.3和UML1.4是两个最重要的修订版本,第四阶段:UML的重大修订UML2 1999:开始酝酿,旨在产生比UML1有显著改进的新版本 20002001:由OMG陆续发布了4个提案需求
35、(RFP) 征集提案,择优采纳 2002年之后先后形成4个UML2.0规范 在OMG的组织下继续修订和改进,目前最新的版本是UML2.4,60,UML是什么不是什么,1、是一种建模语言 ,不是一种建模方法 “Rational统一过程” 不是UML的一部分 2、用于建立系统的分析模型和设计模型,而不是用于编程 3、是一种已被OMG采纳的建模语言规范(specification) 正式场合一般不称作“标准”(standard) 4、部分地采用了形式化语言的定义方式,但并不严格 不是一种形式化语言,不能编译执行或解释执行,“统一建模语言(UML)是一种用来对软件密集型系统制品进行可视化、详述、构造和
36、建档的图形语言,也可用于业务建模以及其它非软件系统。”,61,UML1规范的主要构成部分(1)UML概要(UML Summary): 对UML做概括介绍,包括其构成、动机、目标、范围、特点、历史、现状以及对未来演化的建议。 (2)UML语义(UML Semantics): 定义UML的语法和语义,是定义UML语言的基本文件(3)UML表示法指南(UML Notation Guide) 定义UML的各种模型图 给出各种图中建模元素的可视化表示法,UML1 概况,62,(4)UML外廓范例(UML Example Profiles) 用于软件开发过程的UML外廓 用于业务建模的UML外廓(5)UM
37、L模型交换(UML Model Interchange) 规定了建模工具在实现各种UML模型时需要共同遵守的语言约定,使来自不同厂商的建模工具能够彼此交换和处理各自开发的系统模型。(6)对象约束语言 OCL (Object Constraint Language) 定义了一种对象约束语言,用来描述模型中关于对象的附加约束,是一种形式化的语言。,63,定义建模语言的语言 元-元模型层,实例化,抽象,实例化,实例化,元-元模型(meta-metamodel):元模型的基础体系结构,定义一种说明元模型的语言。 例如:MOF元模型(metamodel):元元模型的一个实例,定义一种说明模型的语言 例如
38、:UML模型(model):元模型的一个实例,定义一种语言来描述信息领域。 例如:教学管理系统 教室类、学生类、课程类用户对象(user object):模型的一个实例,定义一个特定的信息领域。 例如:一个学校 某老师,某学生,某课程,OMG的四层元模型体系结构,64,抽象元类和具体元类,类,类型,接口,构件,结点,关联,泛化,依赖,类目,关系,可泛化元素,模型元素,元素,具体元类,抽象元类,(classifier),65,UML1的9种模型图,静态结构图(Static Structure Diagram) 类图(Class Diagram) 对象图(Object Diagram) 用况图 (
39、Use Case Diagram) 交互图(Interaction Diagram) 顺序图(Sequence Diagram) 协作图(Collaboration Diagram) 状态图(State chart Diagrams) 活动图(Activity Diagrams) 实现图(Implementation Diagrams) 构件图(Component Diagram) 部署图(Deployment Diagram),九种图支持用户从不同的视角进行系统建模,66,关联,类,对象,链,元模型中的实例级概念引起体系结构层次的混乱,67,扩展机制: 附加到其他模型元素之上以,将原有的建模
40、元素特化成一种语义较特殊的新变种,或者表示出它们的某些细节。,约束(constraint) :用于说明某些必须保持为真的命题。 注释(comment): 对模型元素的细节所进行的解释。 标记值(Tagged Value):表示模型元素的附加的特征。 衍型(stereotype): 附加到其他模型元素之上,从而将原有的建模元素定制成一种语义较为特殊的新变种。,衍型的表示法和例子,active 类 名,类 名,界面 类 名,+ 关键词或图标 =,68,UML2的四个规范,UML2 概况,69,UML2的13种模型图,图,结构图,行为图,交互图,类图,构件图,对象图,活动图,用况图,状态机图,部署图
41、,顺序图,通讯图,组合结构图,包图,交互概览图,定时图,支持用户从不同的视角进行系统建模,70,UML与UML2的各种图的对照,71,学习建议:1、重点掌握UML直接提供给应用模型开发者使用的建模元素,即“具体元类”; 熟练地掌握面向对象方法最基本的概念。 2、在13种图中,重点掌握类图、用况图、顺序图、活动图状态机图、构件图。 3、着眼于实际应用,从UML的复杂性中解放出来。 4、切记:UML只是一种建模语言,不是建模方法。它不包括过程,而且是独立于过程的。根据本单位的实际情况选择适当的过程。 5、动手实践,使用工具;选择合适的项目开始实际应用。,72,4.1 引言(本书的宗旨)充分运用面向
42、对象方法的基本概念,限制扩充概念 以往某些OO方法提出了许多扩充概念,问题是: 使方法复杂化增加学习难度和工程开销 缺乏编程语言支持造成模型与源程序不一致 加强过程指导 给出运用最基本的OO概念自然而有效地解决建模问题的策略,包括那些在其他方法中采用扩充概念解决的问题。 强调在类的抽象层次上建立系统模型 所有对象的属性和操作以及对象之间的关系,都通过它们的类来描述,而不是针对个别对象实例进行描述 ,第4章 本书的OOA&D方法概貌,73,面向对象的概念包括以下两种情况: (1)用来构成系统模型的某种基本成分,称为建模元素 (2)在建模中需要遵守的某种原则,不代表任何模型成分,4.2 主要概念,
43、主要建模元素 对象、类(所有的对象都通过类来表示) 属性、操作(类属性和实例属性,被动操作和主动操作) 一般-特殊关系,一般-特殊结构 整体-部分关系,整体-部分结构 关联 (二元关联、多元关联) 消息 (控制流内部的消息,控制流之间的消息),74,主要原则,(1)抽象 什么叫抽象?(回顾定义) OO方法广泛地运用抽象原则,例如: 系统中的对象是对现实世界中事物的抽象, 类是对象的抽象, 一般类是对特殊类的进一步抽象, 属性是事物静态特征的抽象, 操作是事物动态特征的抽象。 过程抽象 任何一个完成确定功能的操作序列,其使用者都可把它看作一个单一的实体,尽管实际上它可能是由一系列更低级的操作完成
44、的。 数据抽象 根据施加于数据之上的操作来定义数据类型,并限定数据的值只能由这些操作来修改和观察。,75,(2)分类 分类就是把具有相同属性和操作的对象划分为一类,用类作为这些对象的抽象描述。 不同程度的抽象可得到不同层次的类,形成一般-特殊结构(又称分类结构)。 强调:在类的抽象层次上建模(3)封装 (4)继承 (5)聚合 (6)关联(7)消息通信 即要求对象之间只能通过消息进行通讯,而不允许在对象之外直接地存取对象内部的属性。,76,(8)粒度控制人们在研究问题时既需要微观的思考,也需要宏观的思考。因此需要控制自己的视野:考虑全局时,注重其大的组成部分,暂时不详察每一部分的具体的细节;考虑
45、某部分的细节时则暂时撇开其余的部分。这就是粒度控制原则。引入包(package)的概念,把模型中的类按一定的规则进行组合,形成一些包,使模型具有大小不同的粒度层次,从而有利于人们对复杂性的控制。,77,(9)行为分析以对象为单位描述系统中的各种行为 任何行为都归属于某个对象,用对象的操作表示。对象的操作只作用于对象自身的属性。 通过消息描述对象之间的行为依赖关系 如果一个对象操作的执行需要另一个对象为它提供服务,则在模型中表现为前者向后者发送消息。 认识行为的起因,区分主动行为和被动行为 用主动对象的主动操作描述主动行为 用对象的被动操作描述被动行为 认识系统的并发行为 在分析阶段根据,根据系
46、统的需求和事物的主动性来认识系统的并发行为。在设计阶段,根据具体的实现条件确定系统中需要设计哪些控制流。,78,4.3 模型及其规约在分析阶段和设计阶段建立的系统模型分别称为OOA模型和OOD模型 正规理解:一个系统模型,应包括建模过程中产生的图形、文字等各种形式的文档。因为,所谓“模型”是指某一级别上的系统抽象描述,构成这种描述的任何资料都是模型的一部分。习惯说法:目前大部分OOA/OOD著作谈到“模型”,一般是指OOA或OOD过程中产生的图形文档。本书采用习惯说法 将模型和模型规约分别讨论OOA和OOD模型包括需求模型、基本模型和辅助模型,通过模型规约 做详细说明,79,基本模型类图 面向
47、对象的建模中最重要、最基本的模型图 集中而完整地体现了面向对象的概念 为面向对象的编程提供了直接、可靠的依据 可以从三个层次来看,需求模型用况图 每个用况是一项系统功能使用情况的说明,把每一类参与者对每一项系统功能的使用情况确切地描述出来,便全面地定义了系统的功能需求,辅助模型其他各种图 对类图起到辅助作用,提供更详细的建模信息,或者从不同的视角来描述系统。例如包图、顺序图、活动图等,模型规约 对上述各种模型图及其模型元素的详细而确切的定义和解释。,80,OOA模型框架,基本模型:类图,模 型 规 约,需求模型:用况图,辅助模型:包图顺序图活动图 ,对象层,特征层,关系层,81,OOD模型框架
48、 从两个侧面来描述,82,确定系统边界,发现参与者,定义用况,发现对象,定义对象 的特征,定义对象 间的关系,原型开发,建立模型规约,建立需求模型,建立基本模型,建立包图,建立辅助模型,建立 活动图,建立 其他图,建立 顺序图,4.4 建模过程,OOA过程,83,问题域部分设计,输入OOA模型,人机交互部分设计,控制驱动部分设计,数据接口部分设计,构件化与系统部署,向OOP输出OOD模型,OOD过程,84,4.5 OOA与OOD的关系,一致的概念与表示法 OOA和OOD采用一致的概念和表示法,从而不存在分析与设计之间的鸿沟。不同的内容、目标和抽象层次OOA:研究问题域和用户需求,运用面向对象的观点发现问题域中与系统责任有关的对象,以及对象的特征和相互关系。目标是建立一个直接映射问题域,符合用户需求的OOA模型。OOD:在OOA模型基础上,针对选定的实现平台进行系统设计,按照实现的要求进行具体的设计,目标是产生一个能够在选定的软硬件平台上实现的OOD模型。OOA模型:抽象层次较高,忽略了与实现有关的因素 OOD模型:抽象层次较低,包含了与实现平台有关的细节,