Java集合是Java面试中必问题,就算是Java基础,但是很多时候我们只是会使用,并没有深入的研究Java集合类的源码,在此结合兰亭风雨大佬Java集合源码剖析专题及自己的理解将Java集合相关知识点整理在此(全部以JDK1.8为例)。
系列文章目录
Java集合类源码分析(一):Java集合类总览
Java集合类源码分析(二):List接口之ArrayList实现类
Java集合类源码分析(三):List接口之ArrayList实现类
Java集合类源码分析(四):List接口之Vector实现类
Java集合类源码分析(五):Map接口之HashMap实现类
Java集合类源码分析(六):Map接口之HashTable实现类
Java集合类源码分析(七):Map接口之LinkedHashMap实现类
Java集合类源码分析(八):Map接口之TreeMap实现类
Java集合类总览
Java集合工具包位于Java.util包下,Java集合框架下大致可以分为如下五个部分:List列表、Set集合、Map映射、迭代器(Iterator、Enumeration)、工具类(Arrays、Collections)。
Java集合框架图如下:
从框架图中可以看出,集合类主要分为两大类:Collection和Map。
Collection
Collection主要分为两大部分:List和Set,它是List、Set等集合高度抽象出来的接口,它包含了这些集合的基本操作。
List接口通常表示一个列表(数组、队列、链表、栈等),其中的元素可以重复,常用实现类为ArrayList和LinkedList及不常用的Vector。另外,LinkedList还是实现了Queue接口,因此也可作为队列使用。
Set接口通常表示一个集合,其中的元素不允许重复(通过hashcode和equals函数保证),常用实现类有HashSet和TreeSet,HashSet是通过Map中的HashMap实现的,而TreeSet是通过Map中的TreeMap实现的。另外,TreeSet还实现了SortedSet接口,因此是有序的集合(集合中的元素要实现Comparable接口,并覆写Compartor函数才行)。
抽象类AbstractCollection、AbstractList和AbstractSet分别实现了Collection、List和Set接口,这就是在Java集合框架中用的很多的适配器设计模式,用这些抽象类去实现接口,在抽象类中实现接口中的若干或全部方法,这样下面的一些类只需直接继承该抽象类,并实现自己需要的方法即可,而不用实现接口中的全部抽象方法。
Map
Map是一个映射接口,其中的每个元素都是一个key-value键值对,同样抽象类AbstractMap通过适配器模式实现了Map接口中的大部分函数,TreeMap、HashMap、WeakHashMap等实现类都通过继承AbstractMap来实现,另外,不常用的HashTable直接实现了Map接口,它和Vector都是JDK1.0就引入的集合类。
Iterator是遍历集合的迭代器(不能遍历Map,只用来遍历Collection),Collection的实现类都实现了iterator()函数,它返回一个Iterator对象,用来遍历集合,ListIterator则专门用来遍历List。而Enumeration则是JDK1.0时引入的,作用与Iterator相同,但它的功能比Iterator要少,它只能在Hashtable、Vector和Stack中使用。
Arrays和Collections是用来操作数组、集合的两个工具类。