热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java各大集合的区别

java各大集合的区别​Java集合也
java各大集合的区别

​ Java集合也称呼为容器,他是由2大接口组曾,一个是Collection主要用来存放单一的元素,另一个是Map接口,主要用来存放K-V的数据。

**List:**存储的元素是有序的,可重复得到。

Set: 存储的元素是无序了,但是不可以重复。

**Queue: **使用特定的排序规则来确定排序顺序,存储的元素是有序的,可以重复的

Map: 使用k-v存储。key是无序的,不可以重复。val是无序的可以重复。

List

ArrayList: Object[] Arrays

Vector: Object[] arrays

LinkedList: 双向链表(JDK1.6之前未循环链表,JDK1.7取消的循环)

Set

HashSet: (无序,唯一)基于HashMap实现,底层采用HashMap来保存元素

**LinkedHashSet: ** LinkedHashSet是HashSet的子类,内部是通过LinkedHashMap来实现。

TreeSet: 有序唯一:红黑树(自平衡的排序二叉树)

Queue

**PriortyQueue: ** Object[] array 数组来实现二叉堆

ArrayQueue: Object[] arrays 数组 + 双指针

Map

HashMap: JDK1.8之前是由数组+链表组成,数组是HashMap的主体,链表主要是为了解决hash冲突存在的,使用拉链法解决hash冲突。在JDK1.8以后在解决hash冲突有了很大的变化,当链表长度大于阈值8并且数组长度大于等于64的时候就会转换为红黑树,否则就是进行数组扩容数组。

LinkedHashMap: LinkedHashMap继承自HashMap,它和hashmap的结构大致相同,只不过他在上面的结构上添加了双向链表,这样可以保证k-v的形式插入,同事也可以通过链表进行相应的操作。

HashTable 数组+链表组成,数组是HashTable的主体,链表主要解决hash冲突。

TreeMap : 红黑树(自平衡的排序二叉树)

Collection

​ 对于Coleection来说,它主要有3大子接口List、Set、Queue

ArrayList和vector的区别

ArrayList是list的主要实现类,底层使用Object[]存储,适合频繁的查找工作,线程不安全

Vector是list的古老的类,底层使用Object[]存储,是线程安全的

ArrayList和LinkedList的去呗

他们都是线程不安全的,ArrayList的底层是数组,LinkedList的底层是双向链表

插入的区别:

当我们Arraylist尾插入的情况时间复杂度就是O(1),如果我们插入的位置不是尾巴,是某个index的位置,那么时间复杂度就是O(n-index)。删除也是同理,因为我们要实现向前向后的移动。

当我们LinkedList实现头插入和尾巴插入删除的时候时间复杂度是O(1),当我们要再在位置i插入或者删除元素的时候,时间复杂度是i,因为我们在移动到指定的位置在开始插入。

随机访问的区别

LinkedList不支持随机访问,但是ArrayList支持随机访问,因为ArrayList实现了RandomAccess接口,所以支持快速随机访问也就是get方法。

内存的占用

​ ArrayList的内存占用是它内部的数组所占用的大小,而LinkedList内存占用的内存是根据元素的个数。

​ ArrayList底层实现了RandomAccess接口,但是这个接口里面是空空的什么也没有写,我想,**这个接口可能就是一个标识吧,标识告诉我们ArrayList是可以实现的随机访问的。**LinkedList没有实现RandomAccess接口时因为它的底层数据结构,而ArrayList的底层是数组天然支持随机访问,而数组要到置顶的位置才可以时间复杂是O(节点的位置),所以不支持随机访问,

Queue

​ Queue是单端队列,遵循这FIFO(先进先出)的规则

ArrayDeque和LinkedList的区别

虽然他们都实现了Deque接口,两者都有队列的功能,他们的区别如下

​ ArrayDeque是基于可变长的数组和双指针实现的。而LinkedList是通过链表来实现的。

​ ArrayDeque不支持NUll值,但是LinkedList支持

​ ArrayDeue插入的时候可能会出现扩容的过程,不过均摊后他的时间复杂度依然是O(1),然后Linked不需要扩容,但是每次插入数据需要申请新的堆空间,均摊的话性能很慢。

PriorityQueue

​ PriorityQueue利用了二叉堆的数据结构实现,底层使用可变长的数组来存数据。

​ PriorityQueue通过堆元素的上符合下沉,实现了在O(Longn)的时间复杂度内插入元素和删除堆顶元素。

​ PriorityQueue不是线程安全的,不支持存储NUll和non-comparable对象

​ priorityQueue默认是小顶堆,达到你是可以接受一个COmparator作为构造参数来改变优先级的规则

Set

hashSet,linkedhashset,treeste都是通过set接口实现的,都可以保证元素的唯一,但是他们都不是线程安全的。

他们的区别主要在他们的底层不一样,hashset的底层是hash表,linkedhashset是链表+hash表元素的插入取出的顺序满足fifo,treeset的底层是红黑树,元素是有序的,排序由自然排序和自定义排序规则。


推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 由二叉树到贪心算法
    二叉树很重要树是数据结构中的重中之重,尤其以各类二叉树为学习的难点。单就面试而言,在 ... [详细]
  • 并发编程 12—— 任务取消与关闭 之 shutdownNow 的局限性
    Java并发编程实践目录并发编程01——ThreadLocal并发编程02——ConcurrentHashMap并发编程03——阻塞队列和生产者-消费者模式并发编程04——闭锁Co ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 深入解析Java多线程与并发库的应用:空中网实习生面试题详解
    本文详细探讨了Java多线程与并发库的高级应用,结合空中网在挑选实习生时的面试题目,深入分析了相关技术要点和实现细节。文章通过具体的代码示例展示了如何使用Semaphore和SynchronousQueue来管理线程同步和任务调度。 ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
author-avatar
渐我素小黑陈琼敏
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有