类图关联详解

合集下载

类图详解

类图详解

基本元素符号:1. 类(Classes)类包含3个组成部分。

第一个是Java中定义的类名。

第二个是属性(attributes)。

第三个是该类提供的方法。

属性和操作之前可附加一个可见性修饰符。

加号(+)表示具有公共可见性。

减号(-)表示私有可见性。

#号表示受保护的可见性。

省略这些修饰符表示具有package(包)级别的可见性。

如果属性或操作具有下划线,表明它是静态的。

在操作中,可同时列出它接受的参数,以及返回类型,如下图所示:2. 包(Package)包是一种常规用途的组合机制。

UML中的一个包直接对应于Java中的一个包。

在Java中,一个包可能含有其他包、类或者同时含有这两者。

进行建模时,你通常拥有逻辑性的包,它主要用于对你的模型进行组织。

你还会拥有物理性的包,它直接转换成系统中的Java包。

每个包的名称对这个包进行了惟一性的标识。

3. 接口(Interface)接口是一系列操作的集合,它指定了一个类所提供的服务。

它直接对应于Java中的一个接口类型。

接口既可用下面的那个图标来表示(上面一个圆圈符号,圆圈符号下面是接口名,中间是直线,直线下面是方法名),也可由附加了<<interface>>的一个标准类来表示。

通常,根据接口在类图上的样子,就能知道与其他类的关系。

关系:1. 依赖(Dependency)实体之间一个“使用”关系暗示一个实体的规范发生变化后,可能影响依赖于它的其他实例。

更具体地说,它可转换为对不在实例作用域内的一个类或对象的任何类型的引用。

其中包括一个局部变量,对通过方法调用而获得的一个对象的引用(如下例所示),或者对一个类的静态方法的引用(同时不存在那个类的一个实例)。

也可利用“依赖”来表示包和包之间的关系。

由于包中含有类,所以你可根据那些包中的各个类之间的关系,表示出包和包的关系。

例如:动物与氧气2. 关联(Association)实体之间的一个结构化关系表明对象是相互连接的。

UML 之 C++类图关系全面剖析

UML 之 C++类图关系全面剖析

UML 之 C++类图关系全面剖析UML的类图关系分为:关联、聚合/组合、依赖、泛化(继承)。

而其中关联又分为双向关联、单向关联、自身关联;下面就让我们一起来看看这些关系究竟是什么,以及它们的区别在哪里。

1、关联双向关联:C1-C2:指双方都知道对方的存在,都可以调用对方的公共属性和方法。

在 GOF的设计模式书上是这样描述的:虽然在分析阶段这种关系是适用的,但我们觉得它对于描述设计模式内的类关系来说显得太抽象了,因为在设计阶段关联关系必须被映射为对象引用或指针。

对象引用本身就是有向的,更适合表达我们所讨论的那种关系。

所以这种关系在设计的时候比较少用到,关联一般都是有向的。

使用ROSE 生成的代码是这样的:class C1...{public:C2* theC2;};class C2...{public:C1* theC1;};双向关联在代码的表现为双方都拥有对方的一个指针,当然也可以是引用或者是值。

单向关联:C3->C4:表示相识关系,指C3知道C4,C3可以调用C4的公共属性和方法。

没有生命期的依赖。

一般是表示为一种引用。

生成代码如下:class C3...{public:C4* theC4;};class C4...{};单向关联的代码就表现为C3有C4的指针,而C4对C3一无所知。

自身关联(反身关联):自己引用自己,带着一个自己的引用。

代码如下:class C14...{public:C14* theC14;};就是在自己的内部有着一个自身的引用。

2、聚合/组合当类之间有整体-部分关系的时候,我们就可以使用组合或者聚合。

聚合:表示C9聚合C10,但是C10可以离开C9而独立存在(独立存在的意思是在某个应用的问题域中这个类的存在有意义。

这句话怎么解,请看下面组合里的解释)。

代码如下:class C9...{public:C10 theC10;};class C10...{};组合(也有人称为包容):一般是实心菱形加实线箭头表示,如上图所示,表示的是C8被C7包容,而且C8不能离开C7而独立存在。

UML图中类之间的关系_依赖,泛化,关联,聚合,组合,实现答辩

UML图中类之间的关系_依赖,泛化,关联,聚合,组合,实现答辩

UML图中类之间的关系:依赖,泛化,关联,聚合,组合,实现1.2.3.4.5.6.类与类图1 类(Class封装了数据和行为,是面向对象的重要组成部分,它是具有相同属性、操作、关系的对象集合的总称。

2 在系统中,每个类具有一定的职责,职责指的是类所担任的任务,即类要完成什么样的功能,要承担什么样的义务。

一个类可以有多种职责,设计得好的类一般只有一种职责,在定义类的时候,将类的职责分解成为类的属性和操作(即方法)。

3 类的属性即类的数据职责,类的操作即类的行为职责一、依赖关系(Dependence依赖关系(Dependence):假设A类的变化引起了B 类的变化,则说名B类依赖于A类。

• 依赖关系(Dependency 是一种使用关系,特定事物的改变有可能会影响到使用该事物的其他事物,在需要表示一个事物使用另一个事物时使用依赖关系。

大多数情况下,依赖关系体现在某个类的方法使用另一个类的对象作为参数。

• 在UML中,依赖关系用带箭头的虚线表示,由依赖的一方指向被依赖的一方。

[java] view plaincopyprint?1. public class Driver2. {3. public void drive(Car car4. {5. car.move(;6. }7. ……8. }9. public class Car10. {11. public void move(12. {13. ......14. }15. ……16. }{car.move(;}……}public class Car{public void move({......}……}依赖关系有如下三种情况:1、A类是B类中的(某中方法的)局部变量;2、A类是B类方法当中的一个参数;3、A类向B类发送消息,从而影响B类发生变化;GeneralizationGeneralization A是B和C的父类,B,C具有公共类(父类)A,说明A是B,C的一般化(概括,也称泛化)• 泛化关系(Generalization也就是继承关系,也称为“is-a-kind-of”关系,泛化关系用于描述父类与子类之间的关系,父类又称作基类或超类,子类又称作派生类。

UML类图及类与类之间的关系

UML类图及类与类之间的关系

UML类图及类与类之间的关系原⽂地址:类图⽤于描述系统中所包含的类以及它们之间的相互关系,帮助⼈们简化对系统的理解,它是系统分析和设计阶段的重要产物,也是系统编码和测试的重要模型依据。

1. 类类(Class)封装了数据和⾏为,是⾯向对象的重要组成部分,它是具有相同属性、操作、关系的对象集合的总称。

在系统中,每个类都具有⼀定的职责,职责指的是类要完成什么样的功能,要承担什么样的义务。

⼀个类可以有多种职责,设计得好的类⼀般只有⼀种职责。

在定义类的时候,将类的职责分解成为类的属性和操作(即⽅法)。

类的属性即类的数据职责,类的操作即类的⾏为职责。

设计类是⾯向对象设计中最重要的组成部分,也是最复杂和最耗时的部分。

在软件系统运⾏时,类将被实例化成对象(Object),对象对应于某个具体的事物,是类的实例(Instance)。

类图(Class Diagram)使⽤出现在系统中的不同类来描述系统的静态结构,它⽤来描述不同的类以及它们之间的关系。

在系统分析与设计阶段,类通常可以分为三种,分别是实体类(Entity Class)、控制类(Control Class)和边界类(Boundary Class),下⾯对这三种类加以简要说明:(1) 实体类:实体类对应系统需求中的每个实体,它们通常需要保存在永久存储体中,⼀般使⽤数据库表或⽂件来记录,实体类既包括存储和传递数据的类,还包括操作数据的类。

实体类来源于需求说明中的名词,如学⽣、商品等。

(2) 控制类:控制类⽤于体现应⽤程序的执⾏逻辑,提供相应的业务操作,将控制类抽象出来可以降低界⾯和数据库之间的耦合度。

控制类⼀般是由动宾结构的短语(动词+名词)转化来的名词,如增加商品对应有⼀个商品增加类,注册对应有⼀个⽤户注册类等(3) 边界类:边界类⽤于对外部⽤户与系统之间的交互对象进⾏抽象,主要包括界⾯类,如对话框、窗⼝、菜单等。

在⾯向对象分析和设计的初级阶段,通常⾸先识别出实体类,绘制初始类图,此时的类图也可称为领域模型,包括实体类及其它们之间的相互关系。

uml各种关系详解

uml各种关系详解

uml各种关系详解UML(统一建模语言)是一种用于软件开发的标准建模语言,它包括了各种关系来描述不同元素之间的交互和联系。

以下是一些常见的UML关系及其详细解释:1. 泛化关系(Generalization),泛化关系用于描述类之间的继承关系,其中一个类(子类)可以继承另一个类(父类)的属性和行为。

泛化关系用带空心三角形的实线表示,三角形指向父类。

2. 实现关系(Realization),实现关系用于描述接口和实现类之间的关系,表示一个类实现了一个接口定义的行为。

实现关系用带空心三角形的虚线表示,三角形指向接口。

3. 关联关系(Association),关联关系描述了类之间的结构关系,表示一个类知道另一个类的存在。

关联关系可以是双向的,也可以是单向的。

在UML中,关联关系用一条直线连接相关的类,可以在连线两端加上多重性和角色名称。

4. 聚合关系(Aggregation),聚合关系表示整体与部分之间的关系,部分可以存在独立于整体之外。

聚合关系用带空心菱形的直线表示,菱形指向整体。

5. 组合关系(Composition),组合关系也表示整体与部分之间的关系,但在组合关系中,部分的生命周期依赖于整体,部分不能独立存在。

组合关系用带实心菱形的直线表示,菱形指向整体。

6. 依赖关系(Dependency),依赖关系表示一个类的实现依赖于另一个类的定义。

依赖关系用带箭头的虚线表示,箭头指向被依赖的类。

以上是UML中常见的几种关系,它们可以帮助软件开发人员更好地理解和描述系统中各个元素之间的交互和联系,从而更好地进行系统设计和开发。

希望这些解释能够帮助你更好地理解UML中各种关系的含义。

UML 之 C++类图关系全面剖析

UML 之 C++类图关系全面剖析

UML 之 C++类图关系全面剖析UML的类图关系分为:关联、聚合/组合、依赖、泛化(继承)。

而其中关联又分为双向关联、单向关联、自身关联;下面就让我们一起来看看这些关系究竟是什么,以及它们的区别在哪里。

1、关联双向关联:C1-C2:指双方都知道对方的存在,都可以调用对方的公共属性和方法。

在 GOF的设计模式书上是这样描述的:虽然在分析阶段这种关系是适用的,但我们觉得它对于描述设计模式内的类关系来说显得太抽象了,因为在设计阶段关联关系必须被映射为对象引用或指针。

对象引用本身就是有向的,更适合表达我们所讨论的那种关系。

所以这种关系在设计的时候比较少用到,关联一般都是有向的。

使用ROSE 生成的代码是这样的:class C1...{public:C2* theC2;};class C2...{public:C1* theC1;};双向关联在代码的表现为双方都拥有对方的一个指针,当然也可以是引用或者是值。

单向关联:C3->C4:表示相识关系,指C3知道C4,C3可以调用C4的公共属性和方法。

没有生命期的依赖。

一般是表示为一种引用。

生成代码如下:class C3...{public:C4* theC4;};class C4...{};单向关联的代码就表现为C3有C4的指针,而C4对C3一无所知。

自身关联(反身关联):自己引用自己,带着一个自己的引用。

代码如下:class C14...{public:C14* theC14;};就是在自己的内部有着一个自身的引用。

2、聚合/组合当类之间有整体-部分关系的时候,我们就可以使用组合或者聚合。

聚合:表示C9聚合C10,但是C10可以离开C9而独立存在(独立存在的意思是在某个应用的问题域中这个类的存在有意义。

这句话怎么解,请看下面组合里的解释)。

代码如下:class C9...{public:C10 theC10;};class C10...{};组合(也有人称为包容):一般是实心菱形加实线箭头表示,如上图所示,表示的是C8被C7包容,而且C8不能离开C7而独立存在。

UML中的类图和数据库设计的关联性探究

UML中的类图和数据库设计的关联性探究

UML中的类图和数据库设计的关联性探究在软件开发过程中,UML(Unified Modeling Language)是一种常用的建模语言,用于描述软件系统的结构和行为。

其中,类图是UML中最常用的图表之一,用于表示系统中的类、属性和方法之间的关系。

而数据库设计则是软件开发过程中的另一个重要环节,涉及到数据的存储和管理。

本文将探讨UML中的类图与数据库设计之间的关联性。

首先,UML中的类图可以直接映射到数据库设计中的表结构。

在类图中,每个类代表了一个实体,而每个属性则代表了实体的属性。

同样地,在数据库设计中,每个表代表了一个实体,而每个字段则代表了实体的属性。

因此,可以通过对类图的分析和设计,直接生成数据库的表结构,从而实现类与表之间的一一对应关系。

其次,UML中的类图可以帮助设计数据库的关系模式。

在类图中,类与类之间的关系可以通过关联、聚合、组合等方式进行表示。

这些关系在数据库设计中可以转化为表与表之间的关系。

例如,一个类图中的关联关系可以转化为数据库中的外键关系,用于表示两个表之间的关联。

而聚合和组合关系则可以转化为数据库中的表之间的关系,用于表示表之间的层次结构。

通过类图的设计,可以更好地理清系统中各个实体之间的关系,从而指导数据库的关系模式设计。

此外,UML中的类图还可以指导数据库的索引设计。

在类图中,类的属性可以分为主属性和外部属性。

主属性通常用于唯一标识一个实体,而外部属性则用于描述实体的特征。

同样地,在数据库设计中,主键可以用于唯一标识一个表中的记录,而外键则用于建立表与表之间的关系。

通过对类图的分析,可以确定哪些属性应该成为主键,哪些属性应该成为外键,从而指导数据库的索引设计,提高数据库的查询效率。

最后,UML中的类图还可以与数据库设计工具进行集成。

目前市面上有许多专业的数据库设计工具,如ERwin、PowerDesigner等。

这些工具可以根据UML中的类图自动生成数据库的表结构,简化了数据库设计的过程。

第三章 类图

第三章 类图

3.1 类图的概念
图3-1电子商务网站的对象模型
3.1 类图的概念
2、类图的作用 类图常用来描述业务或软件系统的组成、结构和关系。
3、类图的组成元素 类 接口 协作 关系 注释 约束 包
3.2 UML中的类
1、类的表示 (1)类的定义
类是具有相似结构、行为和关系的一组对象的描述 符。 (2)类的表示
关于聚合与组合
2、泛化-Generalization
表示两个类元间“一般”与“特殊”的关系。 对应面向对象编程语言中类与类之间的继承关系。 “is a kind of”关系,XX是一种XX
Athlete
SwimmerBiblioteka Golfer3、实现-Realization
表达一种说明元素与实现元素之间的关系; 类和接口之间的关系是实现关系,表示类实现接口提供的
3.2 UML中的类
(7)类的约束 约束指定了类所要满足的一个或多个规则。 在UML中,约
束是用花括号括起来的自由文本。
Washing Machine
Brand name Model name Serial number Capacity Add clothes( ) Add detergent( ) Remove clothes( )
表示客户与提供者之间用不同的方法表现同一个概念, 通常一个概念更抽象,一个概念更具体。包括:
① 跟踪<<trace>>--声明不同模型中的元素之间存在一些 连接但不如映射精确。
② 精化<<refine>>--声明具有两个不同语义层次上的元 素之间的映射。
③ 派生<<derive>>--声明一个实例可以从另一个实例导 出。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

在画类图的时候,理清类和类之间的关系是重点。

类的关系有泛化(Generalization)、实现(Realization)、依赖(Dependency)和关联(Association)。

其中关联又分为一般关联关系和聚合关系(Aggregation),合成关系(Composition)。

下面我们结合实例理解这些关系。

基本概念
类图(Class Diagram): 类图是面向对象系统建模中最常用和最重要的图,是定义其它图的基础。

类图主要是用来显示系统中的类、接口以及它们之间的静态结构和关系的一种静态模型。

类图的3个基本组件:类名、属性、方法。

泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。

直接使用语言中的继承表达。

在类图中使用带三角箭头的实线表示,箭头从子类指向父类。

实现(Realization):在类图中就是接口和实现的关系。

这个没什么好讲的。

在类图中使用带三角箭头的虚线表示,箭头从实现类指向接口。

依赖(Dependency):对象之间最弱的一种关联方式,是临时性的关联。

代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。

一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。

在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。

关联(Association) : 对象之间一种引用关系,比如客户类与订单类之间的关系。

这种关系通常使用类的属性表达。

关联又分为一般关联、聚合关联与组合关联。

后两种在后面分析。

在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。

可以是单向和双向。

聚合(Aggregation) : 表示has-a的关系,是一种不稳定的包含关系。

较强于一般关联,有整体与局部的关系,并且没有了整体,局部也可单独存在。

如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。

在类图使用空心的菱形表示,菱形从局部指向整体。

组合(Composition) : 表示contains-a的关系,是一种强烈的包含关系。

组合类负责被组合类的生命周期。

是一种更强的聚合关系。

部分不能脱离整体存在。

如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。

在类图使用实心的菱形表示,菱形从局部指向整体。

多重性(Multiplicity) : 通常在关联、聚合、组合中使用。

就是代表有多少个关联对象存在。

使用数字..星号(数字)表示。

如下图,一个割接通知可以关联0个到N个故障单。

聚合和组合的区别
这两个比较难理解,重点说一下。

聚合和组合的区别在于:聚合关系是“has-a”关系,组合关系是“contains-a”关系;聚合关系表示整体与部分的关系比较弱,而组合比较强;聚合关系中代表部分事物的对象与代表聚合事物的对象的生存期无关,一旦删除了聚合对象不一定就删除了代表部分事物的对象。

组合中一旦删除了组合对象,同时也就删除了代表部分事物的对象。

实例分析
联通客户响应OSS。

系统有故障单、业务开通、资源核查、割接、业务重保、网络品质性能等功能模块。

现在我们抽出部分需求做为例子讲解。

大家可以参照着类图,好好理解。

1.通知分为一般通知、割接通知、重保通知。

这个是继承关系。

2.NoticeService和实现类NoticeServiceImpl是实现关系。

3.NoticeServiceImpl通过save方法的参数引用Notice,是依赖关系。

同时调用了BaseDao完成功能,也是依赖关系。

4.割接通知和故障单之间通过中间类(通知电路)关联,是一般关联。

5.重保通知和预案库间是聚合关系。

因为预案库可以事先录入,和重保通知没有必然联系,可以独立存在。

在系统中是手工从列表中选择。

删除重保通知,不影响预案。

6.割接通知和需求单之间是聚合关系。

同理,需求单可以独立于割接通知存在。

也就是说删除割接通知,不影响需求单。

7.通知和回复是组合关系。

因为回复不能独立于通知存在。

也就是说删除通知,该条通知对应的回复也要级联删除。

经过以上的分析,相信大家对类的关系已经有比较好的理解了。

大家有什么其它想法或好的见解,欢迎拍砖。

相关文档
最新文档