本文简单介绍了UML建模工具,主要介绍了类之间的几种关系。
类图
上面是一个类图,从上到下依次表示了类名、类的成员变量、类的成员函数。成员变量前面使用+/-/#
分别表示可见性是public,private,protected
接口没有成员变量,所以只有两个格子。
关系
依赖关系
依赖关系指的是一个类的修改会对另一个类产生影响。最简单的例子是一个类使用了另一个类提供的服务。
依赖关系A依赖B表现为:
- B是A的成员变量
- B是A方法的参数
- B是A的基类
从以上可以看出,依赖关系指的是两个类有直接的关系,如果将依赖的类成为client,被依赖的类称为service provider,那么client必须知道service provider的存在,而service provider不需要知道client的存在。其它所有的关系其实都是依赖关系的特殊情况。
实例
继承关系使用箭头加虚线表示。spring 解析xml的过程就是这样的一个依赖关系,为了简单,这里省区了XmlBeanFactory的一个参数。
代码
public class XmlBeanFactory extends DefaultListableBeanFactory {
private final XmlBeanDefinitionReader reader = new XmlBeanDefinitionReaderthis);
/** * Create a new XmlBeanFactory with the given resource, * which must be parsable using DOM. * @param resource XML resource to load bean definitions from * @throws BeansException in case of loading or parsing errors */
public XmlBeanFactoryResource resource) throws BeansException {
thisresource, null);
}
/** * Create a new XmlBeanFactory with the given input stream, * which must be parsable using DOM. * @param resource XML resource to load bean definitions from * @param parentBeanFactory parent bean factory * @throws BeansException in case of loading or parsing errors */
public XmlBeanFactoryResource resource, BeanFactory parentBeanFactory) throws BeansException {
superparentBeanFactory);
this.reader.loadBeanDefinitionsresource);
}
}
继承关系
java的extends和c#的冒号可以实现继承,继承使用实线和三角箭头表示。
实例
上例中的XmlBeanFactory继承了DefaultListableBeanFactory,所以UML类图可以这样表示:
关联关系
关联关系是类似关系型数据库的那种对应关系,例如班级和学生的对应关系,每个班级可以对应多个学生,每个学生有一个班级,关联关系使用实线和箭头表示。
示例
和ER图中的关联关系一样,关联关系依对应的数量不同分为很多种:
- 双向关联
- 单向关联
- 自关联
- 重数关联
重数关联是更一般的关联的描述方法,指明了关联的对象的个数,有如下几种
个数 | 含义 |
---|---|
1…1 | 一个对象只与另一个对象有关系 |
0…1 | 一个对象与另外一个或0个对象有关系 |
1…* | 一个对象与一个或另外多个对象有关系 |
0…* | 一个对象与另外0个或多个对象有关系 |
m…n | 一个对象与另外最少m个最多多个对象有关系 |
聚合关系
聚合关系是一种特殊的关联关系,聚合分为整体和部分两个组件。聚合使用空心菱形和实线加箭头表示
示例
可以看出,engine对car的存在可以没有感知,也就是一个引擎可以装在这个车里,也可以装在另一台车里,部分可以独立于整体之外存在。使用聚合可以将若干个功能重叠的类中可以复用的部分抽离出来,使用聚合来复用抽离出来的功能。
组合关系
组合关系表示的也是部分和整体之间的关系,只是组合的部分也要依赖于整体存在,组合关系使用实心菱形和实线加箭头表示。
示例
这里的嘴和头是相互依赖存在的。
实现关系
实现关系表示类实现接口,实现使用虚线和三角箭头表示:
辨析
- 总的来说,所有的关系都包含了依赖关系,只是有的更加细化。
- 关联包含了组合和聚合,聚合和组合的区别是聚合的部分可以独立于整体存在,组合的部分不能独立于整体存在。