集合篇一

2018-05-20  本文已影响0人  Zhuang_ET

Collection

分为两类:List和Set。JDK不提供直接继承自Collection的类,JDK提供的类都是实现Collection的子接口(List和Set)。
Collection接口存在有何作用?
所有容器的实现类提供了两个“标准”的构造函数来实现:1、一个无参的构造方法;2.一个带有Collection类型单参数的构造方法,用于创建一个具有其参数相同元素新的Collection及其实现类等。实际上:因为所有通用的容器类遵循Collection接口,用第二种构造方法是允许容器之间相互的复制。(即可由Set生成元素相同的List)

List

List是有序的Collection,使用此接口能够精确地控制每个元素插入的位置。用户能够使用索引来访问List中的元素。与Set不同,List允许有相同的元素。List中有get(int index)和set(int index, E e)方法,Set中没有,所以Set无法获取单个元素。实现List接口的类有:ArrayList、LinkedList、Vector、Stack(继承Vector)。

Set

Set的构造函数有一个约束条件,传入的Collection参数不能包含重复的元素。如果一个Set中的可变元素改变了自身状态导致Object.equals(Object)=true,将导致一些问题。
实现Set接口的有:EnumSet、HashSet、TreeSet等。
(List有序可重复、Set无序不可重复。想想正是因为Set无序所以导致其不可重复,本身应该只是想分为有序和无序两类,但因为无序就必须不可重复,因为如果重复了,再加上无序,就无法确定里面重复的元素。

List有序、Set无序:这里的有序、无序指的是存储顺序与插入顺序有没有关系。TreeSet有序的有序指的是它按一定顺序(升序)排序了,但这不是它原来的插入顺序。)

Queue

分两种,双端队列:支持在头、尾两端插入和移除元素;
阻塞式队列:队列满了以后再插入元素则会抛出异常。

Map

HashTable、HashMap、WeakHashMap、TreeMap、LinkedHashMap。
WeakHashMap是一种改进的HashMap。它对Key进行改进,实行“弱引用”,如果一个Key不再被外部所引用,那么该Key可以被GC回收。

总结

异同点

上一篇 下一篇

猜你喜欢

热点阅读