【无标题】

集合框架

集合、数组都是对多个数据进行存储操作的结构,简称Java容器。
此时的存储,注意指的是内存层面的存储,都不涉及持久化的存储(.txt,.jpg,数据库)
接口常见方法

Collection

List

可重复,有下标,存取顺序一致

ArrayList

JDK7: 底层创建长度为10的Object[]数组elementData
JDK8:底层Object[]elementData初始化为{},并没有创建长度为10的数组,第一次调用add()时,底层才创建了长度为10的数组

  • 有序
  • 可重复
  • 底层使用数组
  • 查询速度快,增删慢,getter和setter方法快
  • 容量不足时,ArrayList是当前容量 * 1.5 + 1 【创建时的默认长度为0,无参构造时 0->10, 有参构造且参数为0时 0->1, 传列表构造且列表为空 0->1】
  • 非线程安全
Vector
  • 有序
  • 可重复
  • 线程安全
  • 效率低
  • 容量不够,1倍扩容
LinkedList

优点:链表上的元素在空间存储上,内存地址不联系,在随机增删元素的时候,不需要大量移动元素
缺点:查找效率低,每一次查找都要从头结点开始

  • 有序
  • 可重复
  • 查询慢,增删快,add和remove快
  • 线程不安全

Set

向Set接口中添加的数据,其所在的类一定要重写hashCode()和equals()
重写的hashCode()和equals()尽可能保持一致性,相同的对象具有相同的散列码

HashSet

初始容量为16,扩容后是原来的两倍

  • 无序
  • 不重复
  • 底层使用hash表实现
  • 存取快
  • 内部是hashmap
TreeSet
  • 无序
  • 不可重复
  • 二叉树实现
  • 排序存储
  • 内部是TreeMaphe和socketSet
LinkedHashSet
  • 采用hash表存储,并用双向链表记录插入顺序
  • 内部是LinkedHashMap

Queue

  • 在两端出入的List,可以用数组或链表实现

Map

HashMap

默认容量:16
最大容量: 2^30
加载因子:0.75

  • 键不可重复,值可重复
  • 底层哈希表
  • 线程不安全
  • 允许键值对为空

HashTable

  • 键不可重复,值可重复
  • 底层哈希表
  • 线程安全
  • 不允许键和值为空

TreeMap

  • 键不可重复,值可重复
  • 底层二叉树

转载自:Java集合框架

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值