java聚集_深入理解JAVA中的聚集和组合的区别与联系

选自《JAVA语言程序设计-基础篇(原书第8版)》

定义:一个对象可以包含另一个对象。这两个对象之间的关系称为组合(composition)。

组合实际上是聚集关系的一种特殊形式。聚集模拟了具有(has-a)关系,表示两个对象之间的归属关系。归属关系中的所有者对象称为聚集对象(aggregation object),而它的类称为聚集类(aggregating class)。归属关系中的从属对象称为被聚集类(aggregated object),而它的类被称为被聚集类(aggregated class)。

一个对象可以被几个其他聚集对象所拥有。如果一个对象只归属于一个聚集对象,那么它和聚集对象之间的关系就称为组合(composition)。例如:“一个学生有一个名字”就是组合关系,“一个学生有一个地址”就是聚集关系,因为一个地址可以被几个学生所共享。

UML中,实心菱形表示组合关系,空心菱形表示聚集关系。如图:

18c81d505828dff1035b6daecf8e8e38.png

聚集关系通常被表示为聚集类中的一个数据域,如图:

418f777bb15d4d6e5ee40c284efeefa5.png

聚集还可以存在于同一类的多个对象之间。例如:一个人可能有一个管理者或者多个管理者。一个管理者可用变量表示,多个则可使用数组,如图:

908dca732df9d5b77ce7e6980a296073.png

到这里,基本上聚集和组合的关系就不言自明了。

以上这篇深入理解JAVA中的聚集和组合的区别与联系就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
聚集索引和主键的区别: 1. 聚集索引:聚集索引就是按照表某一列的值对整个表进行排序,使得表的数据物理上按照这一列的值进行存储,因此一个表只能有一个聚集索引,也就是说聚集索引就是表的主索引。在使用聚集索引的情况下,数据的查找速度非常快,但是插入、更新、删除数据时,由于需要保证数据的物理有序性,所以会比较慢。 2. 主键:主键是用来唯一标识一条记录的列,它可以是一个或多个列的组合。主键的作用是保证表的数据的唯一性和完整性,因为主键值不能重复,所以它可以作为表的唯一标识符。主键可以是聚集索引,也可以是非聚集索引。 其他引擎对于聚集索引和主键的实现方式会有所不同,下面简单介绍一下: 1. InnoDB引擎:InnoDB引擎支持聚集索引和非聚集索引,主键默认为聚集索引,如果没有指定主键,则会选择一个唯一非空索引作为主键,如果没有符合条件的索引,则会自动创建一个名为“GEN_CLUST_INDEX”的聚集索引。 2. MyISAM引擎:MyISAM引擎只支持非聚集索引,因此表的每一行数据都是独立存储的,主键也是非聚集索引。 3. Oracle数据库:Oracle数据库聚集索引就是B-tree索引,主键可以是聚集索引或非聚集索引,但是Oracle数据库聚集索引只有在使用了表分区技术时才会起到优化查询的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值