转http://www.uml.org.cn/oobject/201104212.asp
在画类图的时候,理清类和类之间的关系是重点。类的关系有泛化(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. 通知和回复是组合关系。因为回复不能独立于通知存在。也就是说删除通知,该条通知对应的回复也要级联删除。
经过以上的分析,相信大家对类的关系已经有比较好的理解了。大家有什么其它想法或好的见解,欢迎拍砖。
PS:还是那句话:以上类图用Enterprise Architect 7.5所画,在此推荐一下EA,非常不错。可以替代Visio和Rose了。Visio功能不够强大,Rose太重。唯有EA比较合适。
相关推荐
标题“RocketMQ_UML图示说明”和描述表明,本文将讨论淘宝开源的分布式消息中间件RocketMQ的UML图。UML(统一建模语言)是一种标准的图形化建模语言,用于软件系统的建模、设计和文档编制,特别适合于描述系统的结构...
**UML(统一建模语言)实验说明书** UML,全称为Unified Modeling Language,是软件工程领域中一种标准的建模语言,用于图形化表示软件系统的设计和结构。UML是一种可视化工具,它允许开发者、设计师和项目团队通过...
书中不仅涵盖了所有主要类型的UML图示,还提供了清晰的例子和深入浅出的解释。 #### 二、UML基础知识 **1. UML简介** - **定义**:UML是一种用于规格说明、可视化处理、构建和文档化软件系统的标准化建模语言。 -...
4. **注释**:UML提供了注释工具,用于添加额外的说明和解释,帮助理解和解释模型。 5. **标记值**:标记值允许在模型元素上附加额外的信息,如属性值、约束等。 **用例图** 用例图描绘了系统与用户或外部实体...
面向对象设计之3_基于UML的图书管理系统的分析与设计说明 本资源摘要信息主要介绍面向对象设计和UML(Unified Modeling Language)在图书管理系统中的应用。面向对象设计是一种程序设计方法,强调使用对象、类、...
"全书图.rar"可能包含了整个教程的综合图解,这些图可能涵盖UML的所有主要图示类型,帮助读者全面理解UML建模的各个层面。 5. **SQL代码txt** SQL(Structured Query Language)是数据库查询和管理的语言。在UML...
- **答案**: C (类图是UML中表示静态视图的主要图示。) 8. **UML的统一体系结构由__(B)__个主要部分组成** - **答案**: B (UML的体系结构由多个部分组成,这里提到的是4个主要组成部分。) 9. **UML__(B)__价值...
### UML基础知识与考试要点解析 #### UML概述 统一建模语言(Unified Modeling Language,简称UML)是一种标准化的图形表示法,...对于UML的学习和掌握,需要从基础概念入手,逐步深入到具体的图示和技术应用中去。
1. **PPT课件**:详细讲解了UML的基础概念、图示、应用场景和案例分析,帮助学习者理解并掌握UML。 2. **www.pudn.com.txt**:这可能是一个链接或者引用说明,指向一个在线资源平台,可能提供了更多有关UML的学习...
**UML的主要图示** - **类图(Class Diagram)**:展示系统中类、接口及它们之间的关系,如继承、实现、关联等。 - **对象图(Object Diagram)**:类图的实例,显示实际运行时的对象及其关联。 - **序列图(Sequence...
通过这个台湾UML教程,读者不仅可以掌握UML的基本元素和图示,还能了解到如何有效地运用UML进行需求分析、系统设计和项目管理。对于希望提升软件开发效率和质量的人来说,这是一份非常有价值的资料。
其中,UML类图是最常用的一种图示方式,用于描述系统的静态结构。在UML类图中,类与类之间的关系对于理解系统的结构至关重要。本文将详细介绍UML类图中的六种基本关系:依赖、类属、关联、实现、聚合和组合。 #### ...
**UML(统一建模语言)是软件工程领域中一种重要的建模工具,用于系统分析、设计和实现的可视化表达。在软件开发过程中,UML文档...理解和掌握UML的不同图示类型及其应用,对于任何软件开发人员而言都是至关重要的。
《BBS需求说明书UML分析》 ...总之,《BBS需求说明书UML分析》涵盖了BBS系统的基本需求和UML在需求分析中的应用,通过详细的模型和图示,为开发团队提供了一个全面的指南,为BBS系统的构建奠定了坚实的基础。
通过其丰富的图示语言和统一的建模框架,UML使得软件设计更加系统化、可视化,从而提高了开发效率和软件质量。对于任何希望深入理解和掌握软件工程的人来说,熟悉和掌握UML的基本原理和应用技巧都显得尤为重要。
统一建模语言(Unified Modeling Language,简称UML)是一种图形化的标准化建模语言,用于软件开发过程中的规格说明、可视化处理、构造和文档编写。UML不仅支持面向对象的分析与设计,还能描述整个系统架构以及软件...
常见的UML图示包括: - **类图**:描述系统的静态结构,特别是系统中的类、接口以及它们之间的关系。 - **序列图**:描述系统中对象之间的交互顺序。 - **用例图**:描述系统的功能需求,即系统应该做什么。 - **...
UML2.0是UML的最新版本,引入了更多的图示类型、扩展了元模型以及增强了模型的精确性,使得它在现代软件开发中的应用更加广泛。 JBOO4.0是一款基于Java的开源UML建模工具,它专为支持UML2.0而设计,提供了丰富的...