`
eric.zhang
  • 浏览: 126071 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

UML类图与类的关系详解-UML一波流系列

    博客分类:
  • uml
阅读更多
转自:http://peterwei.iteye.com/blog/979557

我们现在再来说说uml中类图和类的关系。

在画类图的时候,理清类和类之间的关系是重点。类的关系有泛化(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比较合适。
  • 大小: 15.3 KB
  • 大小: 27 KB
  • 大小: 15.5 KB
  • 大小: 7.1 KB
  • 大小: 20.3 KB
  • 大小: 15.1 KB
  • 大小: 65.3 KB
  • 大小: 7.3 KB
  • 大小: 37.3 KB
分享到:
评论

相关推荐

    行业分类-设备装置-一种应用于浮式平台的内波流载荷获取方法.zip

    标题中的“行业分类-设备装置-一种应用于浮式平台的内波流载荷获取方法”表明,这个压缩包文件的内容涉及到了海洋工程领域,特别是关于浮式平台的技术应用。浮式平台是海洋油气开发、可再生能源捕获以及科学研究等...

    大数据-算法-三维非结构波流耦合数值模型建立及应用研究.pdf

    论文通过一系列案例验证了模型的性能,如模拟“卡特里娜”飓风引发的风暴潮,结果与实测数据吻合良好。此外,研究还探讨了波浪效应对水位的影响,揭示了辐射应力和波浪引起的表层及底层应力对水位变化的显著作用。 ...

    大数据-算法-波流混合作用的完全非线性数值模拟.pdf

    大数据-算法

    一波流资料压缩包.zip

    很抱歉,根据您提供的信息,"一波流资料压缩包.zip" 的描述过于简洁,没有提供具体的知识点内容。标签为空,且压缩包内的文件名称仅列出了一波流资料压缩包自身,这并不足以生成详细的IT知识。为了提供有价值的IT...

    浸錫深度第二波流動方向.ppt

    【浸錫深度第二波流動方向】是焊接過程中的一個关键概念,主要涉及电子制造中的波峰焊工艺。在這個ppt中,讨论了多个影响焊接质量和效率的因素: 1. **助焊膜厚度**:助焊膜的作用在于保护金属表面免受氧化,促进...

    基于非结构化网格的波流耦合模拟及应用 (2014年)

    波浪与潮流相互作用是近岸海域的关键水动力因素。基于相同的非结构化网格同时模拟潮流和波浪,并通过参数的同步传递,即实现波流的耦合计算。模型中潮流基于三维水动力模型FVCOM,并引入波致辐射应力和水体紊动;...

    Sigrity-Clarity3dWorkbench-USB Connector S-parameter Extraction

    Clarity 3D Workbench为3D-EM全波流提供3D实体建模。 前端界面支持: ■ 导入、创建和修改三维实体模型 ■ 完成设计定义,如材料、边界条件和端口 ■ 设置分析 ■ 发射和跟踪模拟 支持的流量 Clarity 3D Workbench...

    ANSYS海洋平台波浪相位角搜索命令流

    这部分代码创建了一个名为`ANSUO`的输入文件,然后打开一个名为`RFORCE`的输出文件,将所有的相位角与对应的横向力写入该文件中,最后关闭文件并结束程序执行。 #### 总结 通过对上述命令流的详细解析,我们可以...

    波流数值水池模拟研究 (2015年)

    文章首先指出,波流共存的情况比单独考虑波浪或海流更加复杂,因为两者间的相互作用会产生一系列非线性效应。为了研究这一现象,作者基于不可压缩流体的Navier-Stokes (N-S)方程构建了一个数学模型。Navier-Stokes...

    S版三年级上册词句练习大全(下)句子篇.ppt

    - "一个个飞到天上挨着明月渡过天河夕阳西去轻悠悠地飘过大海快乐骄傲与希望"运用了并列句和意象化的语言,表达情感。 2. 课文内容回顾: - 学习的童话有《未填写》、《未填写》;寓言有《未填写》、《未填写》。...

    FlowPlusEditor:编辑人工谐波流+

    7. **教程与支持**:为了方便初学者,FlowPlusEditor可能附带一系列教程和用户文档,指导用户如何使用软件并理解人工谐波流的概念。 8. **协作与版本控制**:考虑到团队工作的需求,FlowPlusEditor可能具备项目共享...

    1.20[EI]ORC用飞龙防HUM AM+FL2本1波流

    1.20[EI]ORC用飞龙防HUM AM+FL2本1波流.

    Sigrity-Clarity 3D Workbench Leadframe Tutorial.rar

    Clarity 3D Workbench为3D-EM全波流提供3D实体建模。 前端界面支持: ■ 导入、创建和修改三维实体模型 ■ 完成设计定义,如材料、边界条件和端口 ■ 设置分析 ■ 发射和跟踪模拟 支持的流量 Clarity 3D Workbench...

Global site tag (gtag.js) - Google Analytics