Java中经常使用的数据结构类

目录

结构体系图
List
Set
Map
附录

结构体系图

List

ArrayList、LinkedList、Vector有什么区别?
  • ArrayList
    • 只能装入引用对象(基本类型要转换为封装类);
    • 线程不安全;
    • 底层由数组实现(顺序表),由于由顺序表实现,因此会具有顺序表的特色,如:须要声明长度、超出长度时须要进行扩容、不适合频繁的移动删除元素、检索元素快;
    • capacity默认为10,超出时,capacity自动增加0.5倍(oldCapacity >> 1)
  • Vector:
    • 只能装入引用对象(基本类型要转换为封装类);
    • Vector经过synchronized方法保证线程安全;
    • 底层也由数组实现;
    • capacity默认为10(在构造方法中),超出时增加capacityIncrement的量,capacityIncrement小于等于0时,则增加1倍((capacityIncrement > 0) ? capacityIncrement : oldCapacity)
  • LinkedList
    • 只能装入引用对象(基本类型会转换为封装类);
    • 线程不安全;
    • 底层实现为链表,具有链表的特色,如:不用声明长度、检索性能较差,可是插入移动删除较快。
    • 链表经过Node对象实现
ArrayList的扩容消耗

因为ArrayList使用
elementData = Arrays.copyOf(elementData, newCapacity);
进行扩容,而
每次都会从新建立一个newLength长度的数组,因此扩容的空间复杂度为O(n),时间复杂度为O(n)html

Arrays.asList方法后的List能够扩容吗?

不能,asList返回的List为只读的。其缘由为:asList方法返回的ArrayList是Arrays的一个内部类,而且没有实现add,remove等操做

而在AbstractList中,add操做
算法

如何使List线程安全

Collections.synchronizedList(list);
或者使用手动的方法保护线程安全。数组

List是有序的吗?

这里的有序指有序性,有序或无序是指是否按照其添加的顺序来存储对象,List是有序的。安全

List怎么实现排序?

实现排序,能够使用自定义排序
list.sort(new Comparator(){...})
或者使用Collections进行快速排序
Collections.sort(list)数据结构

List和Array之间如何互相转换?
  • Array转List:List list = new ArrayList(array);
  • List转Array:Object [] objects = list.toArray();

Set

Set与List有什么区别?
  • Set
    • 只能装入引用对象(基本类型要转换为封装类);
    • 线程不安全
    • 较List,是无序的(没法保证添加的顺序),并且元素不能重复
    • 底层使用了map进行实现(HashMap&LinkedHashMap),借用map的key不能重复的特性,来实现不重复性。

HashSet、LinkedHashSet、TreeSet的区别?

都没法保证线程安全,底层都使用map实现不重复性(因此特性也在map中),Set都不能使用get(index)的方法获取元素,只能使用iterator进行获取。其中:ide

  • HashSet
    • 使用HashMap,没法保证有序性。
  • LinkedHashSet
    • 使用LinkedHashMap,能够保证有序性
  • TreeSet
    • 使用NavigableMap,能够使用Comparator来控制顺序
如何使Set线程安全

Collections.synchronizedSet(set);性能

Map

HashMap、LinkedHashMap、Hashtable、TreeMap的区别?
  • HashMap
    • 线程不安全
    • 容许有一个key为null
    • 经过hash算法,来肯定key是否存在
    • 不能保证有序性
    • 默认大小为16,每次扩容默认增大1倍。默认状况下,数组大小为16,那么当HashMap中元素个数超过16*0.75=12(这个值就是代码中的threshold值,也叫作临界值)的时候,就把数组的大小扩展为 2*16=32,即扩大一倍。
  • LinkedHashMap
    HashMap的子类,将结构与操做更改成链表形式
    • 线程不安全
    • accessOrder默认fasle,能够保证有序性
    • 在HashMap的线性单向链表的基础上,内部维护了一个双向链表
  • Hashtable
    • 父类为Dictionary,与HashMap不一样
    • 线程安全,方法经过synchronized同步
    • key&value都不能为null
    • 不能保证有序性
    • 默认大小为11,其他与HashMap一致
  • TreeMap
    • 线程不安全
    • 内部使用红黑树,须要key实现Comparable接口
    • 能够定义Comparator控制顺序
    • 迭代遍历时使用中序遍历
如何使Map线程安全

Collections.synchronizedMap(map);url

什么样的对象适合作为键,有什么要求?

String、Interger这样的类是final类型的,具备不可变性,且重写了equals()和hashCode()方法。换言之,作为key的对象,不可变性是必要的,由于要计算hashCode(),要防止放入时和取出时hashcode不一致。此外还须要重写equals()和hashCode()方法,用于比较对象一致性。spa

HashMap初始化传入的容量参数的值就是HashMap实际分配的空间么?

不是,是比传入容量参数值大的最小的2的n次方,好比传入6,实际分配8。.net

HashMap的底层数据结构是什么?

是一个数组,结合了顺序表+单向链表的形式,内部的每个节点都是Node对象

 

附录

推荐几篇描述map原理还不错的文章

相关文章
相关标签/搜索