一、依赖关系(Dependence)
只要是在 类中用到了对方,那么它们之间就存在依赖关系。如果没有对象,连编译都通过不了。
Demo:
public class PersonServiceBean {
//类
private PersonDao personDao;
public void save(Person person) {
}
public IDCard getIDCard(Integer personid) {
return new IDCard();
}
public void modify() {
Department department = new Department();
}
}
public class PersonDao {}
public class Person {}
public class IDCard {}
public class Department {}
对应的类图:


小结:
- 类中用到了对方;
- 如果是类的成员属性;
- 如果是方法的返回类型;
- 是方法接收的参数类型;
- 方法中使用到;
二、泛化关系(Generalization)
泛化关系实际上就是继承关系,它是依赖关系的特例。
Demo:
public class DaoSupport {
public void save(Object entity){}
public void delete(Object id){}
}
public class PersonServiceBean extends DaoSupport{
}
对应的类图:


小结:
- 泛化关系实际上就是继承关系;
- 如果 A 类继承了 B 类,我们就说 A 和 B 存在泛化关系;
三、实现关系(Implementation)
实现关系实际上就是 A 类实现 B 接口,它是依赖关系的特例。
Demo:
public interface PersonService {
public void delete(Integer id);
}
public class PersonServiceBean implements PersonService {
@Override
public void delete(Integer id) {
System.out.println("delete..");
}
}
对应的类图:


四、关联关系(Association)
关联关系实际上就是 类与类之间的联系,它是依赖关系的特例。
关联具有导航性:即双向关系或单向关系。
关系具有多重性:如“1”(表示有且仅有一个),“0” (表示 0 个或者多个),“0,1”(表示 0 个或者一个),“n...m”(表示 n 到 m 个都可以),“m...*” (表示至少 m 个)。
Demo:
public class Person {
private IDCard card; //单向关系
private Home home; //双向关系
}
public class IDCard {}
public class Home {
private Person person;
}
对应的类图:

五、聚合关系(Aggregation)
聚合关系表示的是 整体和部分的关系,整体与部分可以分开。
聚合关系是关联关系的特例,所以它具有关联的导航性和多重性。
如:一台电脑由键盘(keyboard)、显示器(monitor),鼠标等组成,组成电脑的各个配件是可以从电脑上分离出来的,使用带空心菱形的实线来表示。
Demo:
public class Computer {
private Mouse mouse; //鼠标可以和computer分离
private Moniter moniter;//显示器可以和Computer分离
public void setMouse(Mouse mouse) {
this.mouse = mouse;
}
public void setMoniter(Moniter moniter) {
this.moniter = moniter;
}
}
public class Moniter {}
public class Mouse {}
对应的类图:


六、组合关系(Composition)
如果像人和头部,心脏不可分离的,则升级为组合关系。
组合关系:也是整体与部分的关系,但是整体与部分不可以分开。
案例:在程序中我们定义实体: Person 与 IDCard、 Head, 那么 Head 和 Person 就是组合, IDCard 和 Person 就是聚合。
但是如果在程序中 Person 实体中定义了对 IDCard 进行级联删除,即删除 Person 时连同 IDCard 一起删除, 那么 IDCard 和 Person 就是组合了。
Demo:
public class Person {
private IDCard card; //聚合关系
private Head head = new Head(); //组合关系
}
public class IDCard {}
public class Head {}
对应的类图:


Demo2:
public class Computer {
/**鼠标可以和computer不能分离**/
private Mouse mouse = new Mouse();
/**显示器可以和Computer不能分离**/
private Moniter moniter = new Moniter();
public void setMouse(Mouse mouse) {
this.mouse = mouse;
}
public void setMoniter(Moniter moniter) {
this.moniter = moniter;
}
}
public class Mouse {}
public class Moniter {}
对应的类图:


【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
2019-10-07 Java 之 Redis 基础
2019-10-07 JavaWeb 之 JSON