java集合类-总纲

Java集合类存放于 java.util 包中,是一个用来存放对象的容器。java

注意:①、集合只能存放对象。好比你存一个 int 型数据 1放入集合中,其实它是自动转换成 Integer 类后存入的,Java中每一种基本类型都有对应的引用类型。编程

   ②、集合存放的是多个对象的引用,对象自己仍是放在堆内存中。数组

   ③、集合能够存放不一样类型,不限数量的数据类型。安全

 

 

在这里,集合类分为了Map和Collection两个大的类别。数据结构

处于图片左上角的那一块灰色里面的四个类(Dictionary、HashTable、Vector、Stack)都是线程安全的,但是它们都是JDK的老的遗留类。现在基本都不怎么使用了,都有了相应的取代类。当中Map是用来取代图片中左上角的那个Dictionary抽象类(Map的官方文档里面有说明)。并发

官方推荐使用Map接口来取代它。相同对于HashTable。官方推荐ConcurrentHashMap来取代。接着如下的Vector是List如下的一个实现类。线程

 

接着最上面的粉红色部分是集合类所有接口关系图。code

当中Map的结构比較简单,而Collection的结构就相对复杂一些。Collection有三个继承接口:List、Queue和Set。对象

 

接下来的绿色部分则是集合类的主要实现类了。继承

这也是咱们最经常使用的集合类了。

 

依照实现接口分类:

实现Map接口的有:EnumMap、IdentityHashMap、HashMap、LinkedHashMap、WeakHashMap、TreeMap

实现List接口的有:ArrayList、LinkedList

实现Set接口的有:HashSet、LinkedHashSet、TreeSet

实现Queue接口的有:PriorityQueue、LinkedList、ArrayQueue

 

依据底层实现的数据结构分类:

底层以数组的形式实现:EnumMap、ArrayList、ArrayQueue
底层以链表的形式实现:LinkedHashSet、LinkedList、LinkedHashMap
底层以hash table的形式实现:HashMap、HashSet、LinkedHashMap、LinkedHashSet、WeakHashMap、IdentityHashMap
底层以红黑树的形式实现:TreeMap、TreeSet
底层以二叉堆的形式实现:PriorityQueue

 

最下方的一个整块都是java.util.concurrent包里面的类,依照包名咱们就可以知道这个包里面的类都是用来处理Java编程中各类并发场景的。

下篇将介绍各经常使用实现类的区别和联系

相关文章
相关标签/搜索