一 HashMap:
1 Map就是存储键值对(<key,value>)的一个集合。
2.HashMap的原理:
HashMap由数组+链表组成的,数组是HashMap的主体,链表则是主要为了解决哈希冲突而存在的
HashMap的主干是一个Entry数组Entry是HashMap的基本组成单元,每一个Entry包含一个key-value键值对。
3.jdk1.7和jdk1.8之间的区别:
jdk1.8在jdk1.7之上增加了红黑树来进行性能优化,即当链表超过8时链表转换为红黑树和数组。
注:HashMap的key是唯一的不能重复,可以为空且只能有一个值为空,value可以重复相同。
扩容机制:loadFactory默认是0.75,设置固定大小2的N次幂方便运算均匀分布。
数据 线程不安全。
重写equls方法必须重写hashcode方法。
二,ConcurrentHashMap
1.概念
锁分段式技术,将数据进行一段一段存储,然后每段数据分配一把锁,当一个线程占用一段数据的时候其他线程也可以访问其他数据
2.数据结构
Node数组+链表+红黑树的数据结构
3.线程安全
CAS+synchronized
三,ArrayList和LinkedList
1.数据结构:ArrayList是动态数组的数据结构,LinkedList是双向链表的数据结构。
2.对于随机访问get和set,ArrayList要优于LinkedList, LinkedList要移动指针比较慢。对于新增和删除操作add和remove ,LinkedList要占优势,Array'List要移动数据。
ArrayList的内部实现是基于基础的对象数组的,因此,它使用get方法访问列表中的任意一个元素时(random access),它的速度要比LinkedList快(O1)。LinkedList中的get方法是按照顺序从列表的一端开始检查,直到另外一端(On)。对LinkedList而言,访问列表中的某个指定元素没有更快的方法了,要对list进行大量的插入和删除操作时,LinkedList也是一个较好的选择。
使用:当操作是在一列数据的后面添加数据而不是在前面或中间,并且需要随机地访问其中的元素时,使用ArrayList会提供比较好的性能;当你的操作是在一列数据的前面或中间添加或删除数据,并且按照顺序访问其中的元素时,就应该使用LinkedList了
Arraylist的主要源码参数:
private static final int DEFAULT_CAPACITY = 10;
// ArrayList的默认长度是多少
private static final Object[] EMPTY_ELEMENTDATA = {};
// ArrayList的默认空元素链表
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
// ArrayList存放的数据
transient Object[] elementData; // non-private to simplify nested class access
// ArrayList的长度
private int size;
扩容机制:(默认的初始长度是10)
扩容的规则也在源码中有体现,扩容后的大小= 原始大小+原始大小/2 + 1。在进行插入等操作的时候,如果判断出大小不够,会依据此方法进行扩容。(以上是JDK1.6版本的源码,在JDK1.7中扩容规则进行了修改,改为了扩容后的大小= 原始大小+原始大小/2)
LinkedList扩容机制:
由于它的底层是用双向链表实现的,没有初始化大小,也没有扩容的机制
网友评论