UML 基础- 全面认识UML 类图元素
开发 Java 应用程序时,开发者要想有效地利用统一建模语言( UML ),必须全面理解 UML 元素以及这些元素如何映射到 Java 。本文重点讨论 UML 类图中的元素。
类图是最常用的 UML 图,它用于描述系统的结构化设计。其中包括类关系以及与每个类关联的属性及行为。类图能出色地表示继承与合成关系。为了将类图作为一种高效的沟通工具使用,开发者必须理解如何将类图上出现的元素转换到 Java 中。下面来进一步探索这一转换过程。
在后面的小节中,分别讲解了类图的各个元素及其在 Java 中相应的表示。我会列出元素名,后续简短的代码片断和一幅图来表示元素在类图上的样子。每一节的最后简要总结了该元素。
类(图 A )是对象的蓝图,其中包含 3 个组成部分。第一个是 Java 中定义的类名。第二个是属性( attributes )。第三个是该类提供的方法。
属性和操作之前可附加一个可见性修饰符。加号( + )表示具有公共可见性。减号( - )表示私有可见性。 # 号表示受保护的可见性。省略这些修饰符表示具有 package (包)级别的可见性。如果属性或操作具有下划线,表明它是静态的。在操作中,可同时列出它接受的参数,以及返回类型,如图 A 的 “Java” 区域所示。
包(图 B )是一种常规用途的组合机制。 UML 中的一个包直接对应于 Java 中的一个包。在 Java 中,一个包可能含有其他包、类或者同时含有这两者。 进行建模时,你通常拥有逻辑性的包,它主要用于对你的模型进行组织。你还会拥有物理性的包,它直接转换成系统中的 Java 包。每个包的名称对这个包进行了 惟一性的标识。
接口(图 C )是一系列操作的集合,它指定了一个类所提供的服务。它直接对应于 Java 中的一个接口类型。接口既可用图 C 的那个图标来表示,也可由附加了 <> 的一个标准类来表示。通常,根据接口在类图上的样子,就能知道与其他类的关系。
后面的例子将针对某个具体目的来独立地展示各种关系。虽然语法无误,但这些例子可进一步精炼,在它们的有效范围内包括更多的语义。
对象之间最弱的一种关联方式,是临时性的关联。代码中一般指由局部变量、函数参数、返回值建立的对于其他对象的调用关系。一个类调用被依赖类中的某些方法而得以完成这个类的一些职责。在类图使用带箭头的虚线表示,箭头从使用类指向被依赖的类。
图D
对象之间一种引用关系,比如客户类与订单类之间的关系。这种关系通常使用类的属性表达。关联又分为一般关联、聚合关联与组合关联。后两种在后面分析。在类图使用带箭头的实线表示,箭头从使用类指向被关联的类。可以是单向和双向。
图 E
表示 has-a 的关系,是一种不稳定的包含关系。较强于一般关联 , 有整体与局部的关系 , 并且没有了整体 , 局部也可单独存在 。如公司和员工的关系,公司包含员工,但如果公司倒闭,员工依然可以换公司。在类图使用空心的菱形表示,菱形从局部指向整体。
图 F
表示 contains-a 的关系,是一种强烈的包含关系。组合类负责被组合类的生命周期。是一种更强的聚合关系。部分不能脱离整体存在。 如公司和部门的关系,没有了公司,部门也不能存在了;调查问卷中问题和选项的关系;订单和订单选项的关系。在类图使用实心的菱形表示,菱形从局部指向整体。
Employee 和 TimeCard 的关系或许更适合表示成 “ 合成 ” ,而不是表示成 “ 关联 ” 。
图G
表示 is-a 的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节。直接使用语言中的继承表达。在类图中使用带三角箭头的实线表示,箭头从子类指向父类。
图H
在类图中就是接口和实现的关系。这个没什么好讲的。在类图中使用带三角箭头的虚线表示,箭头从实现类指向接口。
图I
参考文献:
http://blog.csdn.net/legendinfo/
http://www.iteye.com/topic/979557
《UML 参考手册》
《The Unified Modeling Language Reference Language 》
《标准建模语言UML 及其支持环境》北京航空航天大学软件工程研究所
《UML Programming Guide 》
《OMG Unified Modeling Language Specification 》
《X-Programmar 》