《电子商务系统的分析与设计-第2章 UML.ppt》由会员分享,可在线阅读,更多相关《电子商务系统的分析与设计-第2章 UML.ppt(82页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第第2章统一建模语言章统一建模语言UML目录UML概述概述常用的常用的UML元素分析元素分析UML的通用机制的通用机制小结小结UML的扩展机制的扩展机制UML面向对象的分析设计工具面向对象的分析设计工具oUMLUnified Modeling Language统一建模语言统一建模语言o1996年,由年,由Rational公司的公司的G.Booch、J.Rumbaugh、I.Jacobson共同提出,并由若共同提出,并由若干大公司共同推荐,为干大公司共同推荐,为OMG所采纳,进而成为了所采纳,进而成为了可视化建模的事实标准。可视化建模的事实标准。o目前最新版本目前最新版本2.1.2UML概述oU
2、ML展现了一系列最佳工程实践,这些最佳实践表现在对大规模、复杂系统进行建模方面非常有效。oUML最适于数据建模,业务建模,对象建模,组件建模。oUML作为一种模型语言,它使开发人员专注于建立产品的模型和结构。当模型建立之后,模型可以被UML工具转化成指定的程序语言代码。UML的特点和应用的特点和应用o特点特点n一种一种可视化可视化的语言的语言n一种可用于一种可用于详细描述详细描述的语言的语言o精确精确o无歧义无歧义o完整完整n一种一种构造构造语言语言o正向工程正向工程o逆向工程逆向工程n一种一种文档化文档化的语言的语言o主要应用于软件系统的分析、设计工作,也可应用主要应用于软件系统的分析、设计
3、工作,也可应用于非软件领域于非软件领域?什么是模型o模型就是对一个对象或物体的简化表示。如,地球仪就是一个模型,它是对地球的简化表示。我们可以用模型来表示现实领域中的业务,也可以用模型表示软件领域中的软件组成和结构。日常生活中,常见的模型有很多,如图1所示。o下面按用途对模型进行命名的有:n交通模型:道路交通图、交通标志n建筑模型:建筑物模型、沙盘、公司总部的3D复制品 什么是模型图图1 常见的模型常见的模型n数据分析模型:条形图、饼状图n设计模型:建筑平面图、管线图、电路板设计图 o上面这些模型是用图形符号对现实世界中某个事物的模仿或仿真。o在电子商务系统开发工程中,模型主要用来描述问题域和
4、软件域。问题域主要包括业务、业务规则、业务流程、工作流程;软件域主要包括软件组成、软件结构、软件部署等。什么是模型系统建模的重要性系统建模的重要性引子引子下面先请看下面先请看3个个“小短片小短片”!轻松一下轻松一下引子1盖不好的屋顶?有人要挣钱没?有,有这是我的房子,少个屋顶盖材料我都准备好了材料我都准备好了,给我给我安上就好安上就好.能做的来么能做的来么?放心吧放心吧,没问题没问题!3天过去了天过去了你们!都怎么做的?!一个屋顶搞得坑坑洼洼你们到底做过没,会不会做啊 这个,哪里是放上去那么简单!要想好过程,有个工序,不是光有力气就可以的.之前没做过,不过这个有把子力气不是就可以?这个,这个.
5、我也没想到啊,不就是把屋顶放上去么质量不合格钱,不给了!干这么辛苦竟然没有钱!怎么回家过年啊引子2-HR的烦恼气死人了!PhilPhilMariaMariaHi,Hi,我们在使用你编写的职我们在使用你编写的职员系统时员系统时遇到一个问题遇到一个问题一个职员想把她的名字改一个职员想把她的名字改成成Sparkle StarlightSparkle Starlight系统不允许,你能帮系统不允许,你能帮帮忙吗?帮忙吗?她嫁给了一个姓她嫁给了一个姓Starlight Starlight 的人吗?的人吗?只能在婚姻状况只能在婚姻状况改变时才能更改姓名改变时才能更改姓名不不,他只是要改名字他只是要改名字我
6、从没想过谁会莫名我从没想过谁会莫名其妙地更改自己的姓名其妙地更改自己的姓名每个人只要愿意都可以随每个人只要愿意都可以随时合法更改他(她)们的时合法更改他(她)们的姓名姓名我们希望在下周五之前解我们希望在下周五之前解决这个问题,否则,决这个问题,否则,S p a r k l eS p a r k l e将将不能支付她的账单不能支付她的账单这并不是我的错!我从来不知这并不是我的错!我从来不知道你需要处理这种情况道你需要处理这种情况我现在正我现在正忙着做一个新的性能检测系统忙着做一个新的性能检测系统,并且还要处理职员系统,并且还要处理职员系统的一些需求变更请求的一些需求变更请求我还有别的事。我还有别
7、的事。我只可能在月底前修改好,我只可能在月底前修改好,一周内不行,很抱歉。一周内不行,很抱歉。下次若有类似情况,下次若有类似情况,请早一些告诉我并把它们写下来请早一些告诉我并把它们写下来那我怎么跟那我怎么跟S p a r k l eS p a r k l e说呢?如果她不能支付账说呢?如果她不能支付账单,那她只能挂帐了单,那她只能挂帐了M a r i aM a r i a,你要明白,这不是我的过错,你要明白,这不是我的过错如果你一开始就告诉我,你要能随时改变某个人如果你一开始就告诉我,你要能随时改变某个人的名字,那这些都不会发生的名字,那这些都不会发生该该死死的的计计算算机机引子3如此客户!C
8、ontosoContoso 制药公司的制药公司的高级管理长官高级管理长官Gerhard Gerhard“我们需要建立一套化我们需要建立一套化学制品跟踪信息系统。学制品跟踪信息系统。”“该系统可以记录在库房或某个实验该系统可以记录在库房或某个实验室中已有的化学药品,这样,化学专室中已有的化学药品,这样,化学专家可以直接从楼下的某人那里拿到所家可以直接从楼下的某人那里拿到所需的药品,而不必再买一瓶新的。另需的药品,而不必再买一瓶新的。另外,卫生保健部门也得为联邦政府写外,卫生保健部门也得为联邦政府写些关于化学药品的使用报告。你们小些关于化学药品的使用报告。你们小组能在五个月内开发出该系统来吗?组能
9、在五个月内开发出该系统来吗?”信息系统开发小组的信息系统开发小组的新管理员新管理员CynthiaCynthia“我已经明白这个项目的重我已经明白这个项目的重要性了,要性了,GerhardGerhard”CynthiaCynthia说道。说道。“但在我制定计划前,但在我制定计划前,我们必须收集一些系统的需我们必须收集一些系统的需求。求。”ContosoContoso 制药公司的制药公司的高级管理长官高级管理长官Gerhard Gerhard 信息系统开发小信息系统开发小组的新管理员组的新管理员CynthiaCynthia“你的意思是什你的意思是什么?我不是刚告么?我不是刚告诉你我的需求了诉你我的
10、需求了吗?吗?”“实际上,你只说明了整实际上,你只说明了整个项目的概念与目标个项目的概念与目标”,“这些高层次的业务需求并这些高层次的业务需求并不能为我们提供足够的详细不能为我们提供足够的详细信息以确定究竟要开发什么信息以确定究竟要开发什么样的软件,以及需要多长时样的软件,以及需要多长时间。我需要一些分析人员与间。我需要一些分析人员与一些知道系统使用要求的化一些知道系统使用要求的化学专家进行讨论,然后才能学专家进行讨论,然后才能真正明白达到业务目标所需真正明白达到业务目标所需的各种功能和用户的要求。的各种功能和用户的要求。我们甚至并不需要开发一个我们甚至并不需要开发一个新的软件系统,这样可节省
11、新的软件系统,这样可节省许多钱。许多钱。”“那些化学专家都那些化学专家都非常忙非常忙 ,他们没,他们没有时间与你们详细有时间与你们详细讨论各种细节,你讨论各种细节,你不能让你的手下的不能让你的手下的人说明吗?人说明吗?”“如果我们只是凭空猜想用如果我们只是凭空猜想用户要求,结果不会令人满意。户要求,结果不会令人满意。我们只是软件开发人员,而我们只是软件开发人员,而并非化学专家。我们并不能并非化学专家。我们并不能真正明白化学专家们需要这真正明白化学专家们需要这个化学制品跟踪系统做些什个化学制品跟踪系统做些什么。我曾经尝试过,未真正么。我曾经尝试过,未真正明白这些问题就匆忙开始编明白这些问题就匆忙
12、开始编码,结果没有人对产品满意。码,结果没有人对产品满意。”“行了,行了,我行了,行了,我们没有那么多时间,们没有那么多时间,我来告诉你需求,我来告诉你需求,请马上开始开发系请马上开始开发系统。随时将你们的统。随时将你们的进展情况告诉我。进展情况告诉我。”构建一个软件系统最困难的部分构建一个软件系统最困难的部分是是确定构建什么确定构建什么。其他部分工作。其他部分工作不会像这部分工作一样,在出错不会像这部分工作一样,在出错之后会如此严重地影响随后实现之后会如此严重地影响随后实现的系统,并且在以后修补竟会如的系统,并且在以后修补竟会如此的困难。此的困难。Fred BrooksFred Brooks
13、为什么建模o开发电子商务系统包括两个方面工作:n第一是对业务和业务规则的理解和表示;n第二是规划和设计电子商务系统。o由于业务规模和复杂度不断增加,软件的规模和复杂度也不断增长,人们对业务的理解、对软件的设计和构造越来越困难,只有借助UML这种建模语言来表示和理解业务;o借助UML语言来设计和构造软件系统,通过UML来表示和展现系统组成和交互。o在软件开发活动中,UML主要用于两个方面的建模:对业务建模和对要构造的软件建模。为什么建模为什么建模o1对业务建模n业务建模的目的是理解业务内容和业务过程。你对自己的业务过程建模,不仅是为了理解业务的内容中规定了要做什么,业务是如何进行的,同样也是为了
14、识别业务的变更对业务造成的影响。n对业务建模,有助于你发现业务的优缺点,找出需要改进和优化的地方,在某些情况下还可以对几个可选的业务过程进行仿真。o2对软件建模n软件建模的目的是用UML表示软件的体系和组成,方便软件设计人员理解和修改软件方案,确保软件设计和计划能正确地实现,同时,一旦设计和计划需要修改时,修改后的软件系统,同样经受得起时间的检验。例如,当在一个软件系统中增加一个组件时,你要保证系统不会因为增加了这个组件而崩溃。为什么建模1.建模的目标 o通过对业务和软件系统建模,以实现下面4个目标:n对业务和软件进行可视化,便于对业务和软件系统的理解和交流。n详细说明系统的组成、结构和系统交
15、互的行为。便于开发人员对系统的宏观理解。n用模型的方式为系统提供一个模板,开发人员依据该模板构造软件系统。n将计划和决策文档化。2建模的原则o仅当需要时,才为业务或软件系统构建模型 o按照实际情况或按我们需要的样式,对业务或软件系统进行建模。o依据解决方案,来构造需要的模型。o最好用一组相对独立的模型,从不同的侧面,描述重要的业务或软件系统。常用的常用的UML元素分析元素分析o视图视图(view)nUML是用模型来描述系统的结构或静态特征以及行为或动态特征的,它从不同的视角为系统的架构建模形成系统的不同视图。n视图是表达系统某一方面特征的UML建模构件的子集,在每一类视图中可使用一种或两种特定
16、的图(diagram)来可视化地表示视图中的各种概念。UML的构成的构成o用例视图(用例视图(Use Case diagram)o静态视图(静态视图(Static diagram)n类图类图 Class diagramn对象图对象图 Object diagramn包图包图 Package diagramo状态视图状态视图 Statechart diagramo活动视图活动视图 Activity diagramo交互视图交互视图(Interactive diagram)n顺序图顺序图 Sequence diagramn协作图协作图 Cooperation diagramo实现视图(实现视图(Im
17、plementation diagram)n构件图构件图 Component Diagramn部署图部署图 Deployment Diagram描述系统的动态模型和描述系统的动态模型和组成对象间的交互关系组成对象间的交互关系描述系统组成元描述系统组成元素的静态结构素的静态结构描述对象间的交互描述对象间的交互关系关系描述系统的物理组描述系统的物理组成单元成单元模型管理视图o模型管理视图是对模型自身组织进行的建模,是由自身的一系列模型元素(如类、状态机和用例)构成的包所组成的模型。模型是从某一观点以一定的精确程度对系统所进行的完整描述。o从不同的视角出发,对同一系统可能会建立多个模型,例如有系统分
18、析模型和系统设计模型等等。模型是一种特殊的包。一个包(package)还可以包含其他的包。o整个系统的静态模型实际上可看成是系统最大的包,它直接或间接包含了模型中的所有元素内容。模型管理视图模型管理视图模型管理视图模型管理视图UML构造元素构造元素规则规则公共机制公共机制基本元素基本元素关系关系图图详述详述修饰修饰通用划分通用划分扩展机制扩展机制命名命名范围范围可见性可见性完整性完整性执行执行图图2 UML语言体系语言体系1.构造元素构造元素 构造元素包括基本元素、关系和图。这构造元素包括基本元素、关系和图。这3种元素代表了软件系统或业务系统中的种元素代表了软件系统或业务系统中的某个事物或事物
19、间的关系。某个事物或事物间的关系。2.规则规则 构造元素应该具有命名、范围、可见性、构造元素应该具有命名、范围、可见性、完整性和执行等属性。规则是对软件系完整性和执行等属性。规则是对软件系统或业务系统中的某些事物的约束或规统或业务系统中的某些事物的约束或规定。定。3.公共机制公共机制 公共机制包括详述、修饰、通用划分、公共机制包括详述、修饰、通用划分、扩展机制。公共机制指适用于软件系统扩展机制。公共机制指适用于软件系统或业务系统中每个事物的方法或规则。或业务系统中每个事物的方法或规则。模型元素元素是对模型中最具有代表性的成分的抽象,关系描述了元素之间如何彼此关联、相互依赖或作用的。正是关系把构
20、成系统的诸多元素结合成一个有机的整体。元素元素元素元素o元素是UML模型中面向对象基本的模块,它们在模型中属于静态部分。元素作为对模型中最具有代表性的成分的抽象,在UML中,定义了四种基本的面向对象的元素,分别是结构元素、行为元素、分组元素和注释元素等。UML构造元素基本元素UML构造元素基本元素o结构元素n模型的静态部分:用例、类、接口、协作、组件和节点等。o行为元素n模型的动态部分:交互和状态机o分组元素n模型的组织部分:包o注释元素n模型的解释部分:注解关系关系关系关系oUML模型是由各种事物以及这些事物之间的各种关系构成的。关系是指支配、协调各种模型元素存在并相互使用的规则。oUML中
21、主要包含四种关系,分别是依赖、关联、泛化和实现。UML构造元素关系UML基本元素基本元素 类类(Class)o 表示由三部分构成表示由三部分构成o 名称必须包含名称必须包含o 其余可省略或陆续添加其余可省略或陆续添加o 可说明属性及操作的可见可说明属性及操作的可见性性o 可说明属性的类型可说明属性的类型o 可说明操作的参数、返回可说明操作的参数、返回值值UML基本元素基本元素 对象对象(Object)o 表示由两部分组成表示由两部分组成o 没有操作没有操作o 名称必须包含名称必须包含o 名称带下划线名称带下划线o 名称后可跟类名名称后可跟类名o 其余可省略或陆续添加其余可省略或陆续添加o 可说
22、明属性的类型可说明属性的类型UML基本元素基本元素 用例用例(Use Case)和参与者和参与者(Actor)o参与者参与者n存在于作为研究对象的系存在于作为研究对象的系统之外的实体统之外的实体n可以为人、机构、设备、可以为人、机构、设备、系统等系统等n利用人形表示利用人形表示n通常仅包含其名称通常仅包含其名称o用例用例n对一组动作序列的描述,系对一组动作序列的描述,系统执行这些动作将产生一个统执行这些动作将产生一个对特定参与者有价值而且可对特定参与者有价值而且可观察的结果观察的结果n使用实线椭圆使用实线椭圆n通常仅包含其名称通常仅包含其名称UML基本元素基本元素 关系关系依赖关系(依赖关系(
23、dependency)o代表:使用关系代表:使用关系o说明一个事物规格说明的变化可能影响到使用它的说明一个事物规格说明的变化可能影响到使用它的另一个事物另一个事物o箭头指向被依赖的事物箭头指向被依赖的事物泛化关系(泛化关系(generalization)o指一般事物(称为超类或指一般事物(称为超类或父类)和该事物的较为特父类)和该事物的较为特殊的种类(称为子类)之殊的种类(称为子类)之间的关系间的关系o一个类可以有一个类可以有0个、个、1个或个或多个父类多个父类o没有父类且最少有一个子没有父类且最少有一个子类的类称为根类或基类类的类称为根类或基类o没有子类的类称为叶子类没有子类的类称为叶子类o
24、箭头指向被继承的类箭头指向被继承的类关联关系(关联关系(association)o代表一种结构关系代表一种结构关系o类型类型n自关联自关联n二元关联二元关联o关联可以有一个名称关联可以有一个名称聚集、聚合(聚集、聚合(Aggregation)一种特殊的关联关系一种特殊的关联关系o用于表示整体与部分的关系用于表示整体与部分的关系o以菱形表示以菱形表示o可进一步细分为:可进一步细分为:n普通聚集,共享聚集普通聚集,共享聚集(Shared Aggregation)o整体与部分可以单独存在整体与部分可以单独存在o以空心菱形表示以空心菱形表示n组合(组合(Composition)o整体拥有部分,部分与整
25、体整体拥有部分,部分与整体共存共存o以实心菱形表示以实心菱形表示类及类之间的关系类及类之间的关系自关联自关联同时存在同时存在两种关系两种关系依赖依赖关系关系泛化泛化关系关系多元多元关联关联类及类之间的关系类及类之间的关系类图类图o用于描述类与类之间的静态关系用于描述类与类之间的静态关系o类图主要由类及它们之间的关系构成,此外,还可类图主要由类及它们之间的关系构成,此外,还可以包含接口、包等元素,也可包括对象等实例以包含接口、包等元素,也可包括对象等实例对象图(对象图(Object Diagram)o形式与类图相似形式与类图相似o对象之间的连接使用对象之间的连接使用“链链”(Link)包图(包图
26、(Package Diagram)o目的:将复杂的大系统拆分目的:将复杂的大系统拆分为若干小系统为若干小系统o包:将若干元素集合成一个包:将若干元素集合成一个更高层次的单位,形成一个更高层次的单位,形成一个低耦合、高内聚的元素集合,低耦合、高内聚的元素集合,将其称为包。将其称为包。o包中的元素也具有可见性。包中的元素也具有可见性。o包图利用类似于文件夹的符包图利用类似于文件夹的符号表示包。号表示包。o包图主要描述包之间的包含包图主要描述包之间的包含及依赖关系。及依赖关系。用例图(用例图(Use Case Diagram)o要素要素n参与者参与者n用例用例n关系关系o用例图描述了用例图描述了n谁
27、将是系统的使用者谁将是系统的使用者n使用者希望系统提供什么服务(功能)使用者希望系统提供什么服务(功能)n使用者与系统之间的交互(参与者与用例之间的关系)使用者与系统之间的交互(参与者与用例之间的关系)o关联关系(关联关系(association)n系统所提供的服务(用例之间的关系)系统所提供的服务(用例之间的关系)o包含关系(包含关系(include)o延伸关系(延伸关系(extend)o泛化关系(泛化关系(generalize)用例之间存在的三种可能的关系用例之间存在的三种可能的关系o包含关系(包含关系(include)n表示基础用例(客户用例)在其内部说明的某一位置显式地合并了另一个表示
28、基础用例(客户用例)在其内部说明的某一位置显式地合并了另一个用例的行为用例的行为n用途用途o用例的复用用例的复用o用例的简化用例的简化o延伸关系(延伸关系(extend)n基础用例在由延伸用例间接地说明的一个位置上,隐式地合并了另一个用基础用例在由延伸用例间接地说明的一个位置上,隐式地合并了另一个用例的行为例的行为n特点:即使没有扩展用例,基础用例本身也是完整的特点:即使没有扩展用例,基础用例本身也是完整的n用途用途o把新的行为插入到已有用例中把新的行为插入到已有用例中o把复杂的可选的处理从基本的必须的处理中分离出来把复杂的可选的处理从基本的必须的处理中分离出来o泛化关系(泛化关系(gener
29、alize)n与类的泛化关系相似与类的泛化关系相似n用途用途o先给出一个概念性的用例,再给出其实现用例先给出一个概念性的用例,再给出其实现用例参与者与用例之间的关联关系参与者与用例之间的关联关系用例之间的关系用例之间的关系用例图的主要用途用例图的主要用途o分析阶段分析阶段n帮助识别系统的相关主体帮助识别系统的相关主体n帮助明确并逐步细化系统功能需求帮助明确并逐步细化系统功能需求n是绘制其它图的是绘制其它图的出发点出发点o实现阶段实现阶段n是编制测试用例的基础是编制测试用例的基础o实施阶段实施阶段n是制定培训、维护计划的依据是制定培训、维护计划的依据状态图状态图(Statechart Diagr
30、am)o状态图是对类的一种补充描述,它展示了此类对象所具有的可能的状态以及某些事件发生时其状态的转移情况。o在状态图中,状态由圆角矩形表示。状态的改变称作转移,状态转移由箭头表示,箭头旁可以标出转移发生的条件。状态转移可以伴随有某个动作,它表明当转移发生时系统要做什么。状态图示例状态图示例状态图示例状态图示例活动图活动图(Activity Diagram)o活动图描述系统中各种活动的执行顺序,通常用于描述一个操作中所要进行的各项活动的执行流程。同时,它也常被用来描述一个用例的处理流程,或者某种交互流程。o活动图由一些活动组成,图中同时包括了对这些活动的说明。当一个活动执行完毕之后,控制将沿着控
31、制转移箭头转向下一个活动。活动图中还可以方便地描述控制转移的条件以及并行执行等要求。活动图示例活动图示例加水到容器中加水到容器中将咖啡放到将咖啡放到过滤器中过滤器中点燃咖啡炉点燃咖啡炉取出咖啡杯取出咖啡杯把过滤器放把过滤器放到咖啡炉上到咖啡炉上冲调咖啡冲调咖啡倒咖啡倒咖啡找饮料找饮料取一听取一听可口可乐可口可乐喝饮料喝饮料人人找到可口可乐找到可口可乐没有可口可乐没有可口可乐没有咖啡没有咖啡找到咖啡找到咖啡熄灭咖啡炉熄灭咖啡炉活动图示例活动图示例活动图的主要用途活动图的主要用途o分析阶段分析阶段n辅助进行工作流分析辅助进行工作流分析n辅助对系统中主体行为进行分析辅助对系统中主体行为进行分析o设计
32、阶段设计阶段n设计类的依据设计类的依据n最终细化到程序流程图最终细化到程序流程图交互图(交互图(Interaction Diagram)o与活动图一样,用于对系统的动态特性建模与活动图一样,用于对系统的动态特性建模n交互图强调从对象到对象的控制流交互图强调从对象到对象的控制流n活动图强调从活动到活动的控制流活动图强调从活动到活动的控制流o由由顺序图顺序图和和协作图协作图共同构成共同构成o显示的是一个交互,由一组对象和它们之间显示的是一个交互,由一组对象和它们之间的关系组成,包含它们之间可能传递的消息的关系组成,包含它们之间可能传递的消息o顺序图:强调时间顺序的交互图顺序图:强调时间顺序的交互图
33、o协作图:强调结构组织的交互图协作图:强调结构组织的交互图o两者在语义上是等价的两者在语义上是等价的顺序图(顺序图(Sequence Diagram)o要素要素n对象:沿对象:沿X轴排列轴排列o名称名称o生命线生命线o控制焦点可选,用于可视化消息的嵌套或实际计算发生时的控制焦点可选,用于可视化消息的嵌套或实际计算发生时的时间时间n消息:沿消息:沿Y轴排列轴排列o名称名称o参数(可选)参数(可选)o消息的类型消息的类型n普通消息普通消息n调用调用例子例子1:通过一个简单交易系统来说明通过一个简单交易系统来说明UML交互图交互图 o要达到某个特定的目标,必然要执行一系列的方法调用。要达到某个特定的
34、目标,必然要执行一系列的方法调用。UML序列序列图的典型用途就是显示出方法调用过程。在图的典型用途就是显示出方法调用过程。在UML序列图中,调用一序列图中,调用一个操作就叫做发送一个消息(个操作就叫做发送一个消息(Message)。)。交易事务中计算累计金额的时序图交易事务中计算累计金额的时序图时序图有两个维度:垂直维度以发生的时间顺序显示消息时序图有两个维度:垂直维度以发生的时间顺序显示消息/调用的序列;调用的序列;水平维度显示消息被发送到的对象实例水平维度显示消息被发送到的对象实例对象对象生命生命线线激活激活期期消息消息活动条可以嵌套,表示活动条可以嵌套,表示在前一方法的执行过程在前一方法
35、的执行过程中,又有同一对象的另中,又有同一对象的另一个方法被调用一个方法被调用.交易事务中计算累计金额的相关的代码片断交易事务中计算累计金额的相关的代码片断/*属于属于Sale类:从类:从lineItem的单项金额计算交易总金额,的单项金额计算交易总金额,return交易总额交易总额*/public double calcTotal()total=0.0;Iterator i=lineItems.iterator();while(i.hasNext()total+=(LineItem)i.next().calcTotal();return total;/*属于属于LineItem类:计算当前项
36、目的交易金额,类:计算当前项目的交易金额,return 交易金额交易金额*/public double calcTotal()total=product.calcTotal(this);return total;/*属于属于Product类:计算指定数量的产品价值多少;类:计算指定数量的产品价值多少;return 金额金额*/public double calcTotal(LineItem li)return amount*li.getQuantity();顺序图强调了消息的时间顺序。在画顺序图时,首先将参顺序图强调了消息的时间顺序。在画顺序图时,首先将参与交互作用的对象沿着与交互作用的对象沿
37、着X X轴放在图的顶端,将启动交互作用的轴放在图的顶端,将启动交互作用的对象放在左边,将从属的对象放在右边,将这些对象发送和对象放在左边,将从属的对象放在右边,将这些对象发送和接收的消息按照时间增加的顺序沿着接收的消息按照时间增加的顺序沿着Y Y轴由上而下地放置。轴由上而下地放置。协作图(协作图(Collaboration Diagram)o要素要素n对象:名称对象:名称n链:连接对象之间的弧链:连接对象之间的弧n消息消息o名称名称o参数参数o顺序号:以嵌套的形式反映了消息间的先后顺序顺序号:以嵌套的形式反映了消息间的先后顺序协作图示例交互图的主要用途交互图的主要用途o分析阶段分析阶段n帮助识
38、别系统的相关主体帮助识别系统的相关主体n帮助分析业务流程帮助分析业务流程o设计阶段设计阶段n设计类的操作的重要依据设计类的操作的重要依据n设计程序流程的出发点设计程序流程的出发点o实现阶段实现阶段n是编制测试用例的重要参考是编制测试用例的重要参考构件图o表示系统中的不同物理组件及其联系,表达的是系统代表示系统中的不同物理组件及其联系,表达的是系统代码本身的结构。码本身的结构。配置图o配置图描述系统中硬件和软件的物理配置情配置图描述系统中硬件和软件的物理配置情况和系统体系结构。况和系统体系结构。o由节点组成,节点代表系统的硬件,组件在由节点组成,节点代表系统的硬件,组件在 节点上驻留并执行。配置
39、图表示系统的软件节点上驻留并执行。配置图表示系统的软件 组件与硬件之间的关系,表达的是运行系统组件与硬件之间的关系,表达的是运行系统 的结构。的结构。o组件图和配置图用于建立系统的实现模型。组件图和配置图用于建立系统的实现模型。配置图客户客户A:个人电脑个人电脑PC客户客户B:个人电脑个人电脑PC数据库服务器:数据库服务器:VAX服务器:服务器:02TCP/IP协议TCP/IP协议DecNet协议配置图下图演示了 WebServer通过 HTTP协议与Client PC通信,Client PC通过USB协议与Printer通信。UML的通用机制1.1.1.1.规格说明规格说明规格说明规格说明
40、在UML语言中,每个元素都用一个图形符号表示,同时,对图形符号的语义可以用详细的文字进行描述,这种对图形符号的文字描述称为规格描述,也称为详述。如图所示,对每个用例来说,既有图形描述,也有对应的文字描述,即,详细描述。UML的通用机制2.2.2.2.修饰修饰修饰修饰o在UML的图形表示中,每一个模型元素都有一个基本符号,这个基本符号可视化地表达了模型元素最重要的信息。o用户也可以把各种修饰细节加到这个符号上以扩展其含义。这种添加修饰细节的做法可以为图中的模型元素在一些视觉上的效果上发生一些变化。UML的通用机制3.3.3.3.通用划分通用划分通用划分通用划分o通用划分是一种保证不同抽象概念层次
41、的机制。通常我们可以采用两种方式进行通用划分,一种是对类和对象的划分,另外一种是对接口和实现的分离。o类和对象的划分是指类是一个抽象而对象是这种抽象的一个实例化。类和对象的划分保证了实例及其抽象的划分,从而使得对一组实例对象的公共静态和动态特征无需一一管理和实现,只需要抽象成一个类,通过类的实例化实现对对象实体的管理。UML的通用机制3.3.通用划分通用划分o接口和实现的分离是指接口声明了一个操作接口,但是却不实现其内容,而实现则表示了对该操作接口的具体实现,它负责如实地实现接口的完整语义。o由于接口是要向外公开的,而实现是需要隐藏的(用户不需要知道),这样才能应对变化。比如接口的实现有变化,
42、或者一个接口有多种可能的实现,我们就可以随意修改这些实现,而不影响用户的使用,因为用户看到的只是对外公开的接口,接口并没有变。接口和实现的分离示例#include#includestructInterfacevoid(*f)();/定义了一个接口;voidfun1()/实现1printf(fun1.n);voidfun2()/实现2printf(fun2.n);intmain()Interfacea;a.f=fun1;a.f();a.f=fun2;a.f();system(pause);UML的扩展机制由于UML中的基本元素不能表示所有事物,因此,我们通过一些方法对基本元素进行扩展,主要的扩展
43、机制有:构造型、标记值和约束1.1.1.1.构造型(构造型(构造型(构造型(stereotypestereotypestereotypestereotype)o简而言之,构造型扩展机制的目的就是基于一个已存在的模型元素再重新定义一个新的模型元素。o构造型允许用户对模型元素进行必要的扩展和调整,能够有效地防止UML变得过于复杂。o构造型的一般表现形式为使用“”包含构造型的名称在里面,例如、等。UML的扩展机制2.2.2.2.标记值标记值标记值标记值(tagged value)(tagged value)(tagged value)(tagged value)o标记值是用来为事物(元素)添加新特征
44、的。标记值的表示方法是用形如“标记信息”的字符串表示。这对字符串包含一个标记字符串和一个值字符串,用来存储着有关模型元素或表达元素的一些相关信息。o标记值,可以被我们用来扩展UML构造块的特性,可以根据我们的需要来创建详述元素的新元素。o标记值可以与任何独立元素相关,包括模型元素和表达元素。标记值是当我们需要对一些特性进行记录的时候而给定元素的值。UML的扩展机制3.3.3.3.约束约束约束约束(constraint)(constraint)(constraint)(constraint)o约束机制用于扩展UML构造块的语义,允许建模者和设计人员可以增加新的规则和修改现有的规则。o约束可以表示在 UML的规范表示中不能表示的语义关系,特别是当陈述全局条件或影响许多元素的条件时,约束特别有用。o约束使用大括号和大括号内的字符串表达式表示,即约束的表现形式为约束的内容。约束可以附加在表元素、依赖关系,或注释上。