《面向对象的软件工程.ppt》由会员分享,可在线阅读,更多相关《面向对象的软件工程.ppt(82页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第8章 面向对象的软件工程 第8章 面向对象的软件工程 8.1 软件工程的新途径软件工程的新途径 8.2 面向对象建模面向对象建模 8.3 对象模型对象模型 8.4 动态模型动态模型 8.5 功能模型功能模型 第8章 面向对象的软件工程 8.1 8.1 软件工程的新途径软件工程的新途径8.1.1 8.1.1 面向对象的思想面向对象的思想 在前面,我们介绍了传统的软件工程方法,这部分我们将要介绍一种新方法。20世纪70年代末,面向对象方法学的一些基本概念已在系统工程领域内萌发了出来,如对于系统中的某个模块或构件,可表示为问题空间的一个对象或一类对象。到了20世纪80年代,面向对象的程序设计方法得
2、到了很快的发展,并显示出其强大的生命力,因此使面向对象技术在系统工程、计算机、人工智能等领域得到了广泛的应用。在更高的层次上、更广泛的领域内开展面向对象技术的热点研究是在20世纪90年代,到目前,这种技术已得到了广泛的应用,面向对象方法已成为软件工程的一种新途径。面向对象可以表示为 面向对象(OO,Object Oriented)=对象+类+继承+通信第8章 面向对象的软件工程 面向对象的基本思想是将一个实际问题看成是一个对象或几个对象的集合。面向对象分析过程是在系统所要求解的问题中找出对象(属性和行为)以及它所属的类,并定义对象与类;面向对象设计是把系统所要求解的问题分解为一些对象及对象间传
3、递消息的过程;面向对象实现是把数据和出路数据的过程结合为一个对象。对象既可以像数据一样被处理,又可以像过程一样被描述处理的流程和细节。总之,面向对象分析到面向对象设计再到面向对象实现(即OOAOODOOI)不用转换。第8章 面向对象的软件工程 8.1.2 8.1.2 面向对象的基本概念面向对象的基本概念 1.1.对象对象(Object)(Object)我们把客观世界的实体称之为问题空间(问题域)的对象。例如,一个人可以是一个对象,一条信息可以是一个对象,一本书可以是一个对象,一家图书馆也可以是一个对象。可见,对象是以初始的对象为基本元素,经过层层组合而成的。因此,整个客观世界可认为是一个最复杂
4、的对象。第8章 面向对象的软件工程 对象是一个由信息及有关对它进行处理的描述所组成的包。在面向对象的程序设计中,“对象”是系统中的基本运行实体,也就是说,“对象”是具有特殊属性(数据)和行为方式(方法)的实体。对象的特殊属性就确定了给定时刻对象的状态,用数据值来描述它的状态,例如,用学号、姓名、性别、年龄和专业等数据值描述一个学生对象的状态。与每一个对象相关的方法定义了该对象上的操作,例如,学生信息登记、学生专业查询等方法定义了学生对象的操作。因此,对象是数据和操作的封装体,如图8.1所示。第8章 面向对象的软件工程 图8.1 对象 第8章 面向对象的软件工程 2.2.类类(Class)(Cl
5、ass)1)类的概念 类是对一个或几个相似对象的描述。类是具有相同(或相似)属性和操作的对象的集合,类是对象的抽象,而对象是类的具体化。换句话说,类是对象的模板,而对象是类的实例(Instance)。第8章 面向对象的软件工程 类是一个抽象数据类型的实现,它定义的是一种对象类型,它描述了属于该类型的所有对象的性质。例如,Integer是一个类,它描述了所有整数的性质(包括整数的算术运算和大小比较的实现),“2”、“3”和“5”等这些具体整数都是Integer这个类的对象,都具备算术运算和大小比较的处理能力。所以说,类具有属性,它是对象的状态的抽象,用数据结构来描述类的属性;类具有操作,它是对象
6、的行为的抽象,用操作名和实现该操作的方法来描述类的操作。对象是在执行过程中由其所属的类动态创建的,一个类可以创建多个不同的对象。类中的所有数据是私有的,该数据必须通过类的公共接口(成员函数)来访问。第8章 面向对象的软件工程 2)类的层次 一个类的上层可以有超类(Superclass),下层可以有子类(Subclass),形成一种层次结构。超类也称基类,子类也称派生类。这种类之间的结构关系主要有两种:一般与特殊结构关系和整体与部分结构关系。一般与特殊结构关系又称为分类结构关系,也就是“is a”关系。例如,飞机和交通工具都是类,它们之间的关系是“is a”关系,飞机是一种特殊的交通工具。通常,
7、越上层的类越具有一般性和共性,越下层的类越特殊、越具体。现实世界中的一般化的抽象关系用类的这种结构关系来描述。第8章 面向对象的软件工程 整体与部分结构关系称为组装结构关系,也就是“has a”关系。例如,飞机和发动机都是类,它们之间的关系是“has a”关系,发动机是飞机的一部分。通常,上层的类具有整体性,下层的类具有部分性、成员性。现实世界中的组成的抽象关系用类的这种结构关系来描述。第8章 面向对象的软件工程 3.3.消息和方法消息和方法(Message and Method)(Message and Method)消息用来请求对象执行某一处理或回答某些信息的要求。对象间的通信是通过消息传
8、递来实现的。消息传递是对象间的一种通信机制。某一对象在执行相应的处理时,如果需要,它可以通过传递消息请求其他对象完成某些处理工作或回答某些信息;其他对象在执行所要求的处理活动时,同样可以通过消息传递与别的对象通信。因此,在面向对象程序设计中,程序的执行是靠在对象间传递消息来完成的,如图8.2所示。第8章 面向对象的软件工程 图8.2 消息传递第8章 面向对象的软件工程 发送消息的对象称为发送者,接收消息的对象称为接收者。消息中只包含发送者的要求,它告诉接收者需要完成哪些处理,但并不指示接收者应该怎样完成这些处理。消息完全由接收者解释,接收者独立决定采用什么方式完成所需的处理。发送一条消息必须包
9、含接收者的对象名、发送给该对象的消息名(即对象名.方法名)以及传递消息的参数说明等。参数可以是接收者的局部变量或所有对象都使用的全局变量。方法是类中操作的实现过程。一个方法包含方法名、参数和方法体。当一个对象接收到一条消息后,它所包含的方法决定对象该做怎样的处理。对象的内部信息是隐蔽的(私有的),对象间只能通过消息来连接,而对象私有的数据是用它的方法访问的。第8章 面向对象的软件工程 4.4.继承性继承性(Inheritance)(Inheritance)继承性是共享类、子类和对象中的方法和数据的机制。当类A不但具有类B的属性,而且还具有自己的独特属性时,这时称类A继承了类B,继承关系常称“即
10、是”(is a)关系。当类A继承类B时(如图8.3所示),就表明类A是类B的子类,而类B是类A的超类。子类A由两部分组成:继承部分和增加部分。继承部分是从B继承来的,增加部分是专为A编写的新代码。第8章 面向对象的软件工程 继承具有传递性。类的层次结构的一个重要特点是继承性。一个类(直接)继承其超类的全部描述。这种继承具有传递性,即如果C1继承C2,C2继承C3,则C1(间接)继承C3。所以,一个类实际上继承了层次结构中在其上面的所有类的全部描述。因此,属于某个类的对象除具有该类所描述的特性外,还具有层次结构中该类上面所有类描述的全部特性。继承分为单重继承和多重继承两类。在类的层次结构中,一个
11、类可以有多个子类,也可以有多个超类。如果一个类至多只能有一个超类,则一个类至多只能直接继承一个类,这种继承方式称为单重或简单继承(Single Inheritance),如图8.3所示。简单继承是树型结构。如果一个类可以直接继承多个类,这种继承方式称为多重继承(Multiple Inheritance),如图8.4所示。多重继承是网状结构。第8章 面向对象的软件工程 图8.3 简单继承 第8章 面向对象的软件工程 图8.4 多重继承第8章 面向对象的软件工程 5.5.封装性封装性(Encapsulation)(Encapsulation)封装是面向对象的一个重要概念。封装是一种信息隐蔽技术,用
12、户只能见到对象封装界面上的信息,对象内部对用户是隐蔽的。也就是说,用户只知道某对象是“做什么”的,不知道“怎么做”。封装将外部接口与内部实现分离开来,用户不必知道行为实现的细节,只须用消息来访问该对象。封装体现了良好的模块性,它将定义模块和实现模块分开。封装使对象的内部软件的范围有清楚边界,有一个描述该对象和其他的对象之间通信的接口;使得模快内部的数据受到很好的保护,避免外部的干扰。封装大大增强了软件的维护性、修改性,这也是软件技术追求的目标。第8章 面向对象的软件工程 6.6.多态性多态性(Polymorphism)(Polymorphism)当同样的消息可以被送到一个父类的对象和它的子类的
13、对象上时,被称作多态性。也就是说,在类等级的不同层次中可以共享(公用)一个行为(方法)的名字,然而,不同层次中的每个类却各自按自己的需要来实现这个行为,并得到不同的结果。同一个操作(方法)、函数或过程可以用不同类型的参数调用实现不同的结果。多态即一个名字可具有多种语义。在面向对象的语言中,都有实现多态性的机制,可允许每个对象以自己的解释方式来响应共同的消息。多态性机制不仅增加了面向对象软件系统的灵活性、可理解性和可维护性,进一步减少了信息冗余,而且显著提高了软件的可重用性和可扩充性。第8章 面向对象的软件工程 在面向对象系统中,对象封装了方法,恰好要利用如重名、重定义让各对象以自己的解释方式去
14、执行,而且这种多义性决不会带来混乱,这就是对象的多态性。因为,这些工作不需要涉及具体的数据结构和类型,只是着重于揭示系统的逻辑合理性。这对于需求分析、模型设计极为有利。第8章 面向对象的软件工程 8.2 8.2 面向对象建模面向对象建模 1.1.建模与模型建模与模型 建模是问题域中定义软件解的一种方法。系统开发中,要解决一个实际问题,也就是求该问题的软件解。在解决问题之前,必须首先理解所要解决的问题,其次才是求解。只有对问题理解透彻了,才能解决它。这时我们可以借助于建模的方法来理解问题并解决问题。建模将问题域的解定义成一种模型,以帮助系统分析人员更好地理解问题。第8章 面向对象的软件工程 模型
15、是为了理解问题而对问题作出的一种抽象,而且是对问题的一种无歧义的描述。模型由一组图示符号和组织这些符号的规则组成,利用它们来定义和描述问题域中的术语和概念。或者说,模型是一种思考工具,利用它可以把问题的解规范地表示出来,帮助我们思考问题、定义术语和选择术语以理解问题。第8章 面向对象的软件工程 建模的目的主要是为了减少复杂性。在开发复杂的软件系统时,系统分析员应该从不同角度抽象出目标系统的特性。使用精确的表示方法构造系统的模型,验证模型是否满足用户对目标系统的需求,并在设计过程中逐渐把和实现有关的细节加进模型中,直至最终用程序实现模型。对于那些特别复杂而不能直接理解的系统,更需要建立模型,把复
16、杂的系统分解成若干个子系统、子部分,从而降低系统的复杂程度。第8章 面向对象的软件工程 当系统分析员面对复杂的系统束手无策时,建模是一种有效的方法,模型是一种有效的机制。建立模型后,需要经受用户和各个领域专家的严格评审。审查是为了发现错误和找出目标系统中冗余的需求。然后,清除错误,剔除冗余的需求,挖掘潜在的需求,通过多次修改逐步优化模型,促使软件开发人员透彻地理解问题,从而为软件设计奠定坚实的基础。第8章 面向对象的软件工程 2.2.面向对象模型面向对象模型 面向对象建模是用面向对象技术和方法来定义、描述问题域中的软件解的。对问题域的理解,同样也是面向对象方法开发软件的关键。面向对象方法最基本
17、的原则,是按照人们习惯的思维方式,用面向对象观点建立问题域的模型,开发出尽可能自然地表现求解方法的软件。第8章 面向对象的软件工程 用面向对象方法开发软件,通常需要建立对象模型、动态模型和功能模型三种模型。对象模型是描述系统数据结构的,它始终都是目标系统中最关键、最基本、最核心的;动态模型是描述系统控制结构的;功能模型是描述系统功能的。数据、控制和操作等是这三种模型都涉及到的共同概念,只不过是各自描述的侧重点不同罢了。一个典型的软件系统应包含数据结构(对象模型)、执行操作(动态模型)和完成数据值的变化(功能模型)。这三种模型从不同但又密切相关的角度模拟目标系统,它们各自从不同侧面反映了系统的实
18、质性内容,综合起来则全面地反映了对目标系统的要求。第8章 面向对象的软件工程 用面向对象方法开发软件,在整个开发过程中,三种模型逐步发展、完善。在面向对象分析过程中,构造出完全独立于实现的应用域模型;在面向对象设计过程中,把求解域的结构逐渐加入到模型中;在实现阶段,把应用域和求解域的结构都编成程序代码并进行严格的测试验证。对于大系统来说,建立上述三种模型有助于全面地理解问题域。这三种模型的相对重要程度在不同的应用问题中会有所不同。第8章 面向对象的软件工程 8.3 8.3 对对 象象 模模 型型 对象模型描述了系统的数据结构,它是三个模型的最关键的一个模型。对象模型的作用是描述系统的静态结构,
19、包括构成系统的类和对象、它们的属性和操作,以及它们之间的联系。面向对象方法是以对象为基础来构造系统,而不是以功能为基础来构造系统的。对象模型为建立动态模型和功能模型提供了实质性的框架。对象模型是基础,动态模型和功能模型在此基础上创建。也就是说,一个系统只有创建了对象模型,才能创建动态模型和功能模型。第8章 面向对象的软件工程 在建立对象模型时,我们的目标是从问题域中提炼出对目标系统有价值的概念。用面向对象方法开发软件时,与结构化分析和结构化设计方法不同,各个开发阶段使用的表示方法都是相同的,从前一个阶段到后一个阶段只是做些检查、细化和充实。对象模型的图形符号表示法以及规定组织这些符号的语义规则
20、,即类、对象(类实例)、继承关系、类和(或)对象间其他关系等符号,目前的表示法不统一。面向对象方法学的著名专家,如Grady Booch,Peter CoadEd Yourhon,James Rurnbaugh,Sally Shlaer等人,都提出了自己的表示方法。这些表示方法虽然形式各异,但是,它们有一个共同的特点,那就是独立于具体的开发模式。本书使用Peter CoadEd Yourhon的表示方法。第8章 面向对象的软件工程 8.3.1 8.3.1 类类-对象的表示符号对象的表示符号 1.1.类类-对象对象 “类-对象”是一个专用术语,它代表一个类和该类的对象。表示类-对象的图形符号见图
21、8.5(a),类-对象符号的变种是类符号,表示类的图形符号见图8.5(b)。图8.5 类-对象和类的图形符号第8章 面向对象的软件工程 类符号用一个矩形框表示,由三部分组成,上部分是类的名字,中间部分是该类内定义的属性,下面部分是该类提供的服务,即方法。类-对象符号用类符号外面再加一个虚线框表示,虚线框代表属于该类的对象。一般情况下,类内定义的属性和服务不需写出来,只需在一个矩形框内写上类名代表该类。第8章 面向对象的软件工程 2.2.命名命名 类名是一类对象的名字。命名是否恰当直接影响系统的可理解性。应该使用名词或名词短语命名,例如,图书、课程、公司职员等;尽可能使用专业术语,例如,外部设备
22、、服务台、信号灯等。一般地,应该使用在应用领域中人们习惯的专业术语作为类名,而且含义明确。不要太随便,或刻意创造;名字应该是无歧义性的、简洁的、而且具有描述性的。第8章 面向对象的软件工程 8.3.2 8.3.2 结构的表示符号结构的表示符号 结构是一种思维组织的方式,但在面向对象分析与面向对象设计中,结构是问题域复杂关系的表示,它与系统的任务直接相关,目标系统的任务决定了系统的结构。通常,结构分为一般-特殊结构和整体-部分结构两类。这两种类型的结构均是面向对象分析与面向对象设计方法的重要组成部分。第8章 面向对象的软件工程 1.1.一般一般-特殊结构特殊结构 1)一般-特殊结构的概念 一般-
23、特殊结构也称分类结构(或归纳结构),它是一个类与它的子类之间的分类关系。高层类(即基类)说明一般性的属性,低层类(即派生类)说明特殊属性。低层类对象“即是(is a)”高层类对象的某种特殊情况,它继承了在高层类中定义的属性和服务。换句话说,一般-特殊关系具有继承性,一般类和对象的属性和方法被定义后,即可在特殊类和对象中使用。第8章 面向对象的软件工程 2)2)一般一般-特殊关系表示法特殊关系表示法 一般-特殊关系表示法为:顶部是一个一般类,下部是若干个特殊类,它们之间用线和半圆型标记连接;半圆型的标记表明图形是一般-特殊关系,这种表示法是有向的,从半圆中心画一条线所指到的是特殊类。一般来说,一
24、般类总是放在上部,而特殊类放在下部,这种表示法便于理解模型。一般类与特殊类之间的连线端点应连接到类(而不是对象),这个端点位置表明是类之间的关系,如图8.6所示。第8章 面向对象的软件工程 图8.6 一般-特殊关系表示法第8章 面向对象的软件工程 3)实例 图8.7是一般-特殊关系的例子。在有关于人员的管理系统中,可以将人员定义成一般类,将教师和学生定义成人员的特殊类。它们之间构成一般-特殊关系,这种表示法构成了一般-特殊结构。第8章 面向对象的软件工程 图8.7 一般-特殊关系实例第8章 面向对象的软件工程 2.2.整体整体-部分结构部分结构 1)整体-部分结构的概念 整体-部分结构也称组装
25、结构(聚集结构),它反映了对象之间的构成关系。整体-部分关系是人类思维的基本方法之一。在面向对象分析中,它还能将具有特殊的整体-部分关系的类-对象组织到一起。它对于在问题域和系统任务的边界区域中识别类-&-对象是非常有用的。第8章 面向对象的软件工程 2)整体-部分关系表示法 整体-部分关系表示法为:在顶部是一个整体对象(用类-对象符号表示的对象),下部是组成该整体的若干个部分对象(用类-对象符号表示的对象),它们之间用线与三角标记(结构线)连接。三角标记表明这是整体-部分关系,而且是有向的。通常,把整体对象画在图的上部而把部分对象放在下部,这样布置有助于使模型容易理解。整体可有多个不同种类的
26、部分。整体-部分关系线的终点位置是外框上,反映了对象之间(而不是类之间)的映射关系。整体-部分结构线的每一端都标有一个数量或数量的区域,它表示该整体可以拥有的部分数,反之,表示该部分可以拥有的整体数(当数量为1时可省略),详见图8.8。第8章 面向对象的软件工程 图8.8 整体-部分关系表示法第8章 面向对象的软件工程 3)约束 我们把反映对象之间映射关系中,相互拥有的数量叫约束,即约束是整体与部分相互拥有的数。整体约束部分叫多重性,部分约束整体叫参与性。第8章 面向对象的软件工程 4)实例 图8.9是整体-部分关系的例子。一台微机由主机、显示器组成,主机又由主板、CPU、显卡、硬盘等组成。该
27、图描绘一台微机结构的聚集树,聚集树是多级整体-部分结构的一种简化表示形式。也就是说,如果A是B的一部分,B是C的一部分,则A也是C的一部分,这种性质称传递性。传递性是整体-部分关系的一个最重要的性质。第8章 面向对象的软件工程 图8.9 整体-部分关系实例第8章 面向对象的软件工程 8.3.3 8.3.3 主题主题 1.1.主题的概念主题的概念 主题是一种指导开发者或用户研究大型复杂模型的一种机制。主题又是一种手段,主题有助于分解大型项目以便分组承担任务。它还可以给出面向对象分析和设计的模型总体概貌。主题所依据的原理是整体-部分关系的扩充。一个系统模型可以包含多个主题,也就是说,主题是整个问题
28、域和系统任务的一部分,是用来同整个问题域和系统任务(总体)进行通信的部分。第8章 面向对象的软件工程 2.2.主题的表示法主题的表示法 主题的表示形式有两种:简单表示形式和扩展表示形式。简单表示形式如图8.10所示,只标出主题名和编号;扩展表示形式如图8.11所示,除了标出主题名和编号外,还要标出主题所包含的类。第8章 面向对象的软件工程 图8.10 主题简单表示法 第8章 面向对象的软件工程 图8.11 主题扩展表示法第8章 面向对象的软件工程 8.3.4 8.3.4 关联与链属性关联与链属性 1.1.属性属性 属性是用来描述类-&-对象的特性的。一个属性是一个数据项(状态信息),类中对象都
29、有相应的值(状态)。每个类-&-对象都由属性描述,而属性则按照类-对象的规范来描述。属性放在类-&-对象表示符号的中间部位。第8章 面向对象的软件工程 2.2.关联关系关联关系 1)关联的概念 关联关系反映对象之间相互依赖、相互作用的关系。一个关联关系就是一个问题域映射模型,该模型反映了某个对象对其他对象的需求。关联关系反映了对象之间的静态关系,是二元关系。第8章 面向对象的软件工程 2)关联的表示 关联用两个对象之间的实线来表示。该线的端点位置表明该关联是对象而不是实例之间的映射关系。关联关系分为一对一(1:1)、一对多(1:m)和多对多(m:n)等三种基本类型,类型的划分主要依据参与关联的
30、对象的数目。例如,一个学校有一个校长,学校与校长是一对一的关系;一个教师教许多学生,教师与学生是一对多的关系(关联的表示如图8.12所示);一个学生可选修多门课程,一门课程可被多个学生选修,学生与课程是多对多的关系。第8章 面向对象的软件工程 图8.12 教师与学生之间关联关系 第8章 面向对象的软件工程 3)阶数 对象的每条关联关系上均标有数字(m)或者范围(m,n),它说明了该对象对其他对象的约束。该数字或范围表明可能发生的映射数目或范围。如:“”表示零个或一个,“”表示零个或多个,“1+”表示一个或多个,“1,3”(13)表示该范围的上下限。固定数目的连接可使用单个数字来表示,图8.12
31、与图8.13是两个实例。第8章 面向对象的软件工程 图8.13 一个商场有零个或多个职员关联第8章 面向对象的软件工程 4)链属性 链属性就是关联链的性质。例如,学生与课程之间存在着多对多的关系,但是,每个学生对不同课程拥有不同的选课方式,学生与课程之间的关联链的属性就是选课方式(链属性)。链属性的表示方法如图8.14所示。第8章 面向对象的软件工程 图8.14 链属性的表示方法第8章 面向对象的软件工程 5)受限关联 两个对象加上一个限定词称为受限关联。限定词是一种特殊的链属性。利用限定词通常能有效地减少关联的阶数。例如,某一个学校内的一个系(院)有许多教职工,一个教职工仅属于一个系(院),
32、在一个系(院)内,职工号确定了惟一一个教职工。利用限定词“职工号”表示了系(院)与教职工之间的关系,可见,利用限定词把一对多关系可以简化成一对一关系,如图8.15所示。第8章 面向对象的软件工程 由于系(院)加职工号可惟一地确定一个教职工,因此,限定词“职工号”应该放在靠近系(院)对象的那一端。限定提高了语义精确性,增强了查询能力。在图8.15中,限定的语法表明,职工号在其系(院)内是惟一的。因此,查找一个教职工的方法就是,首先查找所需系(院),然后在该系(院)内查找指定的教职工。第8章 面向对象的软件工程 图8.15 受限关联表示方法第8章 面向对象的软件工程 8.3.5 8.3.5 服务与
33、消息连接服务与消息连接 1.1.服务服务 服务是指某个对象所具有的特定的行为,一个服务就是收到一条消息之后所执行的处理。服务放在类-&-对象表示符号的下部。第8章 面向对象的软件工程 2.2.消息连接的概念消息连接的概念 消息是对象之间传送的信息,消息连接是指一个对象到另一个对象的映射。消息的连接,反映了一个对象对另一个对象的处理依赖关系。该关系表明,一个对象为了完成自己的任务,需要借助于另一个对象提供的服务时,发送(发送者)一个消息给另一个对象(接收者),接收者接收到消息,经过处理后,将结果反馈给发送者。消息连接反映了对象之间的动态关系。第8章 面向对象的软件工程 3.3.消息连接的表示消息
34、连接的表示 消息连接可以用一个带有箭头的实线来表示。箭头从发送者指向接收者。箭头的每一端通常都连接到一个对象(或偶尔到一个类),以表明实际的参加者,如图8.16所示。图8.16 消息连接的表示第8章 面向对象的软件工程 8.3.6 8.3.6 对象模型举例对象模型举例 对象模型把面向对象的概念(对象、类、继承等)与传统方法中常用的数据建模概念结合了起来,从而改进和拓展了普通的数据模型,增强了模型的可理解性和表达能力。图8.17是一个图书借阅管理的对象模型,它表明该公司有许多名职员为之工作,职员又进一步划分为馆长和管理员两类;馆长可对图书借阅工作进行管理,每名管理员可管理多本图书,每本图书可由多
35、名管理员管理;图书拥有许多读者,借书证号惟一地确定一个读者;读者又可分为教师和学生两类,每名教师或学生可以借阅数本图书,每一种图书可供多名教师或学生借阅。这个对象模型描述了类-对象所具有的属性,以及类-对象提供的服务。第8章 面向对象的软件工程 图8.17 图书借阅管理的对象模型第8章 面向对象的软件工程 8.4 8.4 动动 态态 模模 型型 动态模型表示瞬时的、行为化的系统的控制性质,它描述了系统的控制结构。动态模型考察在任何时刻对象及其联系的改变,从对象的事件和状态的角度出发,表现对象的相互行为,规定对象模型中对象的合法变化序列。第8章 面向对象的软件工程 动态模型侧重于系统的控制逻辑,
36、它包括状态图和事件追踪图。状态图用来描绘对象的状态、触发状态转换的事件以及对象的行为(对事件的响应);事件追踪图侧重于说明发生于系统执行过程中的一个事件序列。动态模型由多个状态图组成。每个类的动态行为用一张状态图来描绘,各个类的状态图通过共享事件组合起来,从而构成系统的动态模型。也就是说,动态模型是基于事件共享而互相关联的一组状态图的集合。第8章 面向对象的软件工程 1.1.事件事件 1)事件的概念 事件是某个特定时刻所发生的事情,是某事物发生的信息,它使对象从一种状态转换到另一种状态。事件没有持续时间,是瞬间完成的。事件就是引起对象状态转换的控制信息。模型中,各对象之间相互触发,一个触发行为
37、称作一个事件。对象对事件的响应,取决于接收该触发的对象当时所处的状态,响应包括改变自己的状态或者又形成一个新的触发行为。第8章 面向对象的软件工程 事件从一个对象向另一个对象传送信息。这种信息传送可视为单向传送。发送事件的对象可能期望对方答复,被此事件触发的对象,可以发送答复事件也可以不发送答复事件。如果发送答复事件,该答复事件也是受被触发对象所控制的一个独立事件。第8章 面向对象的软件工程 2)事件类 事件类由各个独立事件的共同结构和行为抽象组成。有些事件类可能传送的是简单的“要发生某事件”的信息,而其他事件类则可能传送的是数据值。由事件传送的数据值叫属性。属性可以在事件类名之后用括号列出,
38、如表8.1所示。表表8.1 8.1 事件类的属性描述事件类的属性描述事 件 类属 性描 述列车出发按下鼠标按钮数字拨号线路、班次、城市按钮、位置数字列车出发(线路、班次、城市)按下鼠标按钮(按钮、位置)数字拨号(数字)第8章 面向对象的软件工程 2.2.状态状态 1)状态的概念 状态是对对象属性值的一种抽象。也就是说,对象所具有的属性值称为对象的状态。状态是影响对象的重要行为的体现,状态表明了对象对输入事件的响应。各对象之间相互触发(即作用),就形成了一系列的状态变化。第8章 面向对象的软件工程 2)状态的特性 状态具有时间性。事件表示时刻,状态代表时间间隔。一个对象在接收事件前后是两个不同的
39、状态,换句话说,同一个对象,在接收两个事件之间是一个状态。状态依赖于接收的事件序列。状态具有持续性,需要一段时间间隔表示一个状态。状态与连续的活动有关,这些活动需要一定的时间才能完成。状态与事件相互依赖,一个事件可将两个状态分开,一个状态可将两个事件隔开。第8章 面向对象的软件工程 3.3.行为行为 行为是指被事件触发的对象达到某种状态时,所做的一系列处理操作。这些操作是需要耗费一定时间的。第8章 面向对象的软件工程 4.4.脚本脚本 脚本也叫场景(Scenarios)。脚本是指系统在某一执行期间内出现的一系列事件。脚本通常起始于一个系统外部的输入事件,结束于一个系统外部的输出事件。脚本可以包
40、括系统中所有事件,也可以只包括某些对象触发或产生的事件。表8.2给出使用电话的脚本,该脚本包括影响电话线的事件:第8章 面向对象的软件工程 表表8.2 8.2 使用电话的脚本使用电话的脚本编号事 件编号事 件1呼叫者拿起电话10呼叫者拨号(4)2响拨号声 11电话鸣响声3呼叫者拨电话号码(2)12接收者拿起电话4拨号声停 13停鸣响声5呼叫者拨号(3)14电话接通6呼叫者拨号(3)15通电话7呼叫者拨号(6)16接收者挂断电话8呼叫者拨号(6)17电话中断9呼叫者拨号(5)18呼叫者挂断电话第8章 面向对象的软件工程 5.5.事件追踪图事件追踪图 1)事件追踪图的概念 事件追踪图侧重于描述发生
41、于系统执行过程中的一个特定“场景”(脚本),是完成系统某个功能的一个事件序列。写好脚本后,需要确定事件追踪,即确定在对象之间传送信息的各个事件。即首先标识每个事件的发送者对象和接收者对象,然后,用事件追踪图按事件序列顺序,来表示事件、事件的发送者对象和事件的接收者对象。第8章 面向对象的软件工程 2)事件追踪图的画法 事件追踪图中,用竖线表示对象,带箭头的横线表示事件,箭头从发送者对象指向接收者对象。时间自上向下延续,与间隔的空间无关,没有精确的时序,请参见图8.18。第8章 面向对象的软件工程 图8.18 打电话事件追踪图第8章 面向对象的软件工程 6.6.状态图状态图 1)状态图的概念 状
42、态图是一个状态与事件的网络,它侧重于描述每一类对象的动态行为。状态是某一时刻中属性特征的概括,而状态转换则表示这一类对象在何时,对系统内外发生的哪些事件作出何种响应。第8章 面向对象的软件工程 2)状态图的画法 用圆形框或椭圆框表示状态,框内可标上状态名也可以不给状态命名,行为在框内用关键字do(后接冒号)标明。用箭头线表示从一个状态到另一个状态的转换,附加在箭头线上的短语标明触发此状态转换的事件名,如图8.19所示。有些事件是简单事件(如图中“事件A”),而有些事件则是条件事件(如“事件B条件”),此时,必须在事件名后面加一个方括号内写上状态转换的条件。条件事件当条件满足时,该事件的发生才能
43、引起状态的转换。用实心圆表示初始状态,用一对同心圆表示最终状态。状态图描述一个对象的个体行为,而事件追踪图则描述多个对象所表现出来的集体行为。它们从不同的角度说明同一系统行为,因此,必然存在着密切的内在联系。第8章 面向对象的软件工程 图8.19 状态图第8章 面向对象的软件工程 8.5 8.5 功功 能能 模模 型型 1.1.功能模型概念功能模型概念 功能模型由多个数据流图组成。它表明了从外部输入,通过操作和内部存储,直到外部输出的整个的数据流情况,它还包括了对象模型内部数据间的限制。但数据流图不指出控制或对象的结构信息,它们在动态模型和对象模型中已描述。在面向对象方法学中,数据流图不像在结
44、构化方法中那样重要。但是,建立功能模型有助于软件开发人员更深入地理解问题域,改进和完善自己的设计。第8章 面向对象的软件工程 2.2.三种模型之间的关系三种模型之间的关系 面向对象建模技术的三种模型,分别从三个不同侧面描述了所要开发的系统。这三种模型相互补充、相互配合,使得我们对系统的认识更加全面。功能模型定义了系统应该“做什么”;动态模型明确定义了“何时做”(即在何种状态下接受了什么事件的触发);对象模型则定义了“对谁做”。对象模型是最基本、最重要的,动态模型和功能模型的建立是以对象模型为基础的。对象模型侧重于描述系统数据结构;动态模型侧重于描述系统控制结构,它由多个状态图组成;功能模型侧重于描述系统功能(系统内部数据的传送和处理),它由多个数据流图组成。三种模型都包含了数据、控制和操作等共同概念,只是各自描述的侧重程度不同。