Java常用数据结构与集合

数据结构

数组:

  • 内存地址连续
  • 检索效率高(可以通过下标访问成员)
  • 增删操作效率低(保证数据越界的问题,需动态扩容)
  • 长度固定,扩容的需要新的数组复制或者Arrays类的copyOf方法

链表

  • 内存地址不连续
  • 查询快删除慢,因为需要移动指针
  • 又分双向链表和单向链表,单向链表有下一个元素的指针,双向有指向上一个,下一个两个指针

双向链表的结构

    static final class Node {// 前一个节点volatile Node prev;// 后一个节点volatile Node next;// 链表节点存储的具体数据volatile Thread thread;}

队列

  • 尾插头删
  • 管状结构,先进先出

  • 尾插尾删
  • 杯状结构,先进后出

集合框架

HashMap

  • 底层是数组+链表的结构,hash值相同的会形成链表,jdk1.8之后当相同hash值超过8个之后会变为红黑树
  • 并不是线程安全的,如果想要一个安全的collections.synchronizedMap返回一个线程安全的。或者使用concurrentHashMap
  • 允许一个key为null,多个value为null

HashTable

  • 是一个古老的Map实现类,它不允许使用null作为键和值。Hashtable的性能略低于HashMap,多线程安全。

LinkedHashMap

  • 底层是数组+链表+双向链表,根据添加顺序排序;线程不安全。
  • 数组和链表的作用和HashMap的作用一样,双向链表是来记录键值对的插入顺序或访问顺序

TreeMap

  • 底层是红黑树,默认是根据键值字典排序就是无序,也可以自己排序。compareable接口或者Comparator
  • 线程安全。

ConcurrentHashMap

  • ConcurrentHashMap底层采用分段的数组+链表实现,线程安全。通过分段锁的方式保证线程安全,默认性能提高16倍。超过75%时扩容,仅扩容当前分段数组
  • 1.7的实现是使用Segment数组,每个Segment就是一个分段锁,对应了一个HashEntry数组。每个HashEntry对应着一个node数组。get()时需要计算两次Hash,第一次拿到Segment,第二次拿到对应的hashEntry。1.8后只需要一次了。1.8之后去掉了Sement分段锁,直接以HashEntry为锁,这样减少了锁的粒度,也减少了冲突的概率。除了去掉Segment外,把node数组更换为红黑树,空间复杂度也从O(n)变为O(logn)
     

HashSet

  • 不重复且无序,允许有一个null
  • 因为源自hashmap所以hash冲突时解决方法一样

LinkedHashSet

  • 不重复且有序
  • 添加的双向链表定义了迭代顺序,即按照将元素插入到集合中的顺序(插入顺序)进行迭代

TreeSet

  • 底层是红黑树,默认是根据键值字典排序就是无序,也可以自己排序。compareable接口或者Comparator
  • 查询和删除都很快
  • 线程不安全

ArrayList

  • 存取有序、可重复
  • 添加第一个元素时,底层会创建一个新的长度为10的数组。扩容1.5倍
  • 大量数据的查询、 少量数据的增删

LinkedList

  • 双链表 、查询慢、增删快
  • 线程不安全


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/614890.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Springboot的餐厅点餐系统

基于SpringbootVue的餐厅点餐系统的设计与实现 开发语言:Java数据库:MySQL技术:SpringbootMybatis工具:IDEA、Maven、Navicat 系统展示 首页展示 菜品详情页 菜品信息 个人中心 后台管理 菜品信息管理 用户管理 菜…

为什么负载电流增加时电源电压会下降?

原文来自微信公众号:工程师看海,与我联系:chunhou0820 看海原创视频教程:《运放秘籍》 大家好,我是工程师看海。 在以前的文章中我总是提到当负载电流增加时,电源的输出电压会下降,很多同学在实…

Kubernetes学习笔记12

k8s核心概念:控制器: 我们删除Pod是可以直接删除的,如果生产环境中的误操作,Pod同样也会被轻易地被删除掉。 所以,在K8s中引入另外一个概念:Controller(控制器)的概念,…

mysql索引与优化问题

作为一个java程序员,mysql数据库面试应该是比较多的了;而关于数据库的面试,最多的就是性能问题,而以性能为起点,延伸出很多具体的问题。 我们使用第一性原理的方法来分析,为什么面试中一定会问数据库的索引…

70 个常用的GIS Python 库

由于其多功能性、广泛的库生态系统和用户友好的语法,Python 已成为地理信息系统 (GIS) 和遥感领域的主导语言。这个 70 个地理空间 Python 库的汇编展示了可用于 GIS 和遥感数据处理和分析的丰富工具包。 Python 在 GIS 中的重要性源于它处理复杂地理空间数据的能力…

【学习】软件测试人员使用Loadrunner进行性能测试的优势

在软件测试领域,性能测试是一项至关重要的环节,它关乎到软件系统的稳定性和用户体验。而在这其中,Loadrunner作为一款久经考验的性能测试工具,凭借其独特的优势,成为了众多企业和开发者眼中的“得力助手”。 首先&…

打造你的私有云盘:安全优先、支持分享 | 开源日报 No.222

nextcloud/server Stars: 25.2k License: AGPL-3.0 nextcloud/server 是一个安全的数据存储空间,可以存储文件、联系人、日历等,并在各设备之间同步。用户可以分享数据并通过应用商店扩展功能。该项目提供加密机制、HackerOne 悬赏计划和双因素认证以确…

2024阿里云学生服务器申请图文全流程,学生机免费续费攻略

2024年阿里云学生服务器免费申请,完成学生认证可以领取1个月免费学生机,完成任务可以再免费学费6个月时长,还可以领取高校计划学生300元无门槛优惠代金券,阿里云服务器网aliyunfuwuqi.com整理2024年最新阿里云大学生服务器申请入口…

2024年重庆市三支一扶考试报名详细流程

2024年重庆市三支一扶考试报名详细流程

【vue】defineEmits 传值 子传父

先行知识 【vue】导入组件【vue】defineProps 传数据 父传子 传值流程 App.vue <template><Header getWeb"emitsGetWeb" userAdd"emitsUserAdd"/><hr /><p>web.name: {{ web.name }}</p><p>web.url: {{ web.url }}&…

STL函数对象

1&#xff0c;函数对象 1.1 函数对象概念 概念&#xff1a; 重载函数调用操作符的类&#xff0c;其对象常称为函数对象函数对象使用重载的&#xff08;&#xff09;时&#xff0c;行为类似函数调用&#xff0c;也称为仿函数 本质&#xff1a; 函数对象&#xff08;仿函数&…

【网站项目】数学辅导微信小程序

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…