栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【无标题】

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【无标题】

集合框架

集合、数组都是对多个数据进行存储操作的结构,简称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集合框架

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/886176.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号