UML类图表达
什么是UML类图?
类图显示了一组类、接口、协作以及他们之间的关系。在UML中问题域最终要被逐步转化,通过类来建模,通过编程语言构建这些类从而实现系统。类加上他们之间的关系就构成了类图,类图中还可以包含接口、包等元素,也可以包括对象、链等实例。
类与类之间的关系
类与类之间的关系可以根据关系的强度依次分为以下五种:
依赖关系(Dependency)---关联关系(Association)---聚合(Aggregation)---组合(Composition)---泛化(Generalization)
1. 依赖关系
依赖关系是五种关系中耦合最小的一种关系。使用虚线加箭头表示,如下图所示:
代码:
- class Person
- {
- public void Call()
- {
- Phone phone = new Phone();
- }
- }
- class Phone
- {
- }
解释:Person 和 Phone之间是没有关系的,但是由于偶尔的需要,Person需要使用Phone,在Person类中的具体方法中需要实例化Phone,这时Person就依赖于Phone.持有Phone类的是Person类的一个方法,而不是Person类,这点是最重要的。
依赖表现为:局部变量,方法中的参数和对静态方法的调用。
2. 关联关系
关联关系是实线加箭头表示。表示类之间的关系比依赖要强,如下图所示:
代码:
- class Person
- {
- public:
- //头部是人的一个属性
- Head head;
- Person()
- {
- // TODO Auto-generated constructor stub
- }
- }
- class Head
- {
- public:
- Head()
- {
- // TODO Auto-generated constructor stub
- }
- }
解释:Head是作为Person类的一个内部属性来使用,一旦实例化了Person类,同时也实例化了一个Head实例,所以他们的依赖性更强。与关联最大的区别是:依赖时是在类的内部具体方法中使用到另外一个类,而关联则是作为内部属性来用,依赖关系仅当具体方法被调用时才会实例化,比如刚才的Person只有打电话时才调用Phone实例化,而关联是在new一个Person时就同时实例化了一个Head类来作为Person的内部属性.
3. 聚合关系
聚合关系通过一个空心的菱形加箭头表示,如下图所示:
代码:
- class PersonGroup
- {
- public:
- Person person;
- //将person作为构造方法的参数传进去
- PersonGroup(Person person)
- {
- // TODO Auto-generated constructor stub
- this.person = person;
- }
- }
- class Person
- {
- public:
- Person()
- {
- // TODO Auto-generated constructor stub
- }
- }
解释:Person类是PersonGroup构造方法的参数,因此可以Person类可以完全脱离PersonGroup类而存在,不会因为PersonGroup实例的消亡而消亡,就像现实生活中,人不会因为脱离人群就挂了...
4. 组合关系
组合关系通过一个实心的菱形加箭头表示,如下图所示:
代码:
- class Person
- {
- public:
- Foot foot;
- Person()
- {
- // TODO Auto-generated constructor stub
- //在构造方法中实例化
- foot = new Foot();
- }
- }
- class Foot
- {
- public:
- Foot()
- {
- // TODO Auto-generated constructor stub
- }
- }
解释:
Foot类是在Person类的构造方法中才被具体实例化,一旦Person实例生成,则Foot实例也生成,当Person实例消亡,其Foot实例也消亡,就像现实生活中,生成一个人,并定会伴随着脚的生成,但是如果那个人挂了,它的脚自然而然也就没了。
5. 泛化关系
泛化关系通常包含类与类之间的继承关系和类与接口实现关系,如下图所示:
继承:
接口:
解释:
泛化(generalization)关系是一个类(称为子类、子接口)继承另外的一个类(称为父类、父接口)的功能,并可以增加它自己的新功能的能力,继承是类与类或者接口与接口之间最常见的关系
作者:白菜菜白
出处:http://www.cnblogs.com/lvchaoshun/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。