Java常用集合比较

Java常用集合比较

1. ArrayList

  基于数组方式实现,无容量的限制。

  在执行插入元素时可能要扩容,在删除元素时并不会减少数组的容量。

  如果希望相应的缩小数组容量,可以调用trimToSize()

  在查找元素时要遍历数组,对于非null的元素采取equals的方式寻找。

  非线程安全。

2. LinkedList

  基于双向链表机制实现。

  元素的插入、移动较快。

  非线程安全。

3. Vector

  基于Object数组的方式来实现的。

  基于synchronized实现的线程安全的ArrayList。

  在插入元素时容量扩充的机制和ArrayList稍有不同:
  如果capcacityIncrement > 0, 则Object数组的大小扩大为现有size加上capcacityIncrement;
  如果capcacityIncrement < 0, 则Object数组的大小扩大为现有size的两倍;

4. Stack

  基于Vector实现,支持LIFO。

5. HashSet

  基于HashMap实现,无容量限制。

  不允许元素重复。

  非线程安全。

6. TreeSet

  基于TreeMap实现,支持排序。

  非线程安全。

7. HashMap

  采用数组方式存储key、value构成的Entry对象,无容量限制。

  基于key hash寻找Entry对象存放到数组的位置,对于hash冲突采用链表的方式来解决。

  在插入元素时可能会扩大数组的容量,在扩大容量时会重新计算hash,并复制对象到新的数组中。

  非线程安全。

8. TreeMap

  基于红黑树实现,无容量限制。

  非线程安全。

-----------------------------------
适用场景:

  对于查找和删除较为频繁,且元素数量较多的应用,Set或Map是更好的选择;

  ArrayList适用于通过为位置来读取元素的场景;

  LinkedList 适用于要头尾操作或插入指定位置的场景;

  Vector 适用于要线程安全的ArrayList的场景;

  Stack 适用于线程安全的LIFO场景;

  HashSet 适用于对排序没有要求的非重复元素的存放;

  TreeSet 适用于要排序的非重复元素的存放;

  HashMap 适用于大部分key-value的存取场景;

  TreeMap 适用于需排序存放的key-value场景。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值