java集合

ArrayList和LinkedListd异同

1)ArrayList和LinkedList读书不同步的,是线程不安全的。
2)底层数据结构ArrayList采用数组,LinkedList采用双向链表。
3)数据范围、数据修改、暂用看见几数组及链表的区别。

ArrayList 与 Vector 区别

Vector的方法是同步的,同一时刻只能一个线程访问一个Vector对象(耗时)
Vector中所有公有方法都采用synchronized修饰,

![](https://img2018.cnblogs.com/blog/1200829/201909/1200829-20190929111307050-913360206.png)

ArrayList是非线程同步的。

HashMap的底层实现及与Hashtable的区别

1)JDK1.8之前采用数组+链表的形式
2)JDK1.8之后采用数组+链表+红黑树,链表长度达到阈值(8)时转化为红黑树。
3) Hashtable是线程安全的,故效率低于HashMap。
4) HashMap可以一个键为null多个值为null,Hashtable不允许键和值为空。
5)扩容方式:
    Hashtable 认的初始大小为11,之后每次扩充,容量变为原来的2n+1。
    HashMap 认的初始化大小为16。之后每次扩充,容量变为原来的2倍。
    
增加ConcurrentHashMap综合二者优势,可进行分段锁。Hashtable(全表锁)

HashSet

1)无序(通过hash排序)
2)唯一(插入时比较hash值,hash值相同在比较eques比地址)

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...