美文网首页
集合篇一

集合篇一

作者: Zhuang_ET | 来源:发表于2018-05-20 17:02 被阅读0次

    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回收。

    总结

    异同点

    • Vector和ArrayList
      1.Vector线程同步,所以是线程安全的,而ArrayList线程不安全,多线程使用Vector,单线程使用ArrayList效率一般更高。
      2.如果集合中的元素数目大于目前集合数组长度时,Vector增长率为目前数组长度的100%,而ArrayList为50%,如果在集合中使用数据量比较大的数据,使用Vector。
    • ArrayList和LinkedList
      1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。
      2.对于随机访问get和set,ArrayList优于LinkedList,因为LinkedList要移动指针。
      3.对于新增和删除操作的add和remove,LinkedList占优势,因为ArrayList要移动数据。
    • HashMap和TreeMap
      1.HashMap底层基于哈希表的Map接口实现,TreeMap底层基于红黑树实现。
      (HashSet底层基于HashMap实现,TreeSet底层基于TreeMap实现)。
      2.HashMap通过hashcode对其内容进行快速查找,而TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果就应该使用TreeMap(HashMap中元素的排列顺序是不固定的)。
      3.在Map中插入、删除和定位元素,HashMap是最好的选择,但如果要按自然顺序或自定义顺序遍历键,那么TreeMap会更好。
    • HashTable和HashMap
      1.HashTable基于Dictionary类,而HashMap基于Map接口实现。
      2.HashTable是线程安全的,也就是同步的,而HashMap是线程不安全的,不同步的。
      3.只有HashMap可以让你将空值作为一个表的条目的key和value。

    相关文章

      网友评论

          本文标题:集合篇一

          本文链接:https://www.haomeiwen.com/subject/cypodftx.html