Java中常用集合类对比_集合比较

集合实现类集合接口有序性唯一性线程安全空值性能排序数据结构索引应用场景备注
ArrayListList有序可重复不安全允许空值查找效率高,添加/删除效率低使用 Collections.sort() 传入ArrayList,会采
用默认的方式进行排序(字典序)。
自己实现 Comparator 接口,再使用 Collections.sort() 来
实现自定义排序
数组下标索引适合快速随机查找和遍历,不适合插入和删除,当操作是在一列数据的后面添加数据而不是在前面或者中间,并需要随机地访问其中的元素时,使用ArrayList性能比较好数组空间不够,ArrayList默认扩展50%的大小。
VectorList有序可重复安全允许空值查找效率高,添加/删除效率低-数组下标索引-可以看做线程安全ArrayList,已弃用,由 CopyOnWriteArrayList 或者 Collections.synchronizedList 替代
LinkedListList有序可重复不安全允许空值查找效率底,添加/删除效率高-双向链表下标索引当对一列数据的前面或者中间执行添加或者删除操作时,并且按照顺序访问其中的元素时,要使用LinkedListLinkedList 提供了List接口中没有定义的方法,专门用于操作表头和表尾元素,可以当作堆栈、队列和双向队列使用
StackList有序可重复安全允许空值查找效率高,添加/删除效率低,整体效率低-无索引-继承自Vector,堆栈,后进先出,已弃用,由 ArrayDeque 或者 ConcurrentLinkedQueue 替代
HashMapMap无序,无法保证键值对的顺序key不可重复,value可重复,使用 hashCode 与 equals 方法保证key不重复不安全允许空值,key允许一个null,value允许多个nullHashMap通常比TreeMap、LinkedHashMap 快,不过有种情况例外,当HashMap容量很大,实际数据较少时,遍历起来可能会比 LinkedHashMap 慢-JDK7:数组+链表;JDK8:数组+链表+红黑树无索引场景遍历使用的是Iterator迭代器,系统调用key的 hashCode() 方法得到其 hashCode 值,得到这个对象的 hashCode 值之后,系统会根据该 hashCode 值来决定key—value的存储位置
HashtableMap无序,无法保证键值对的顺序key 不可重复,value 可重复,使用 hashCode 与 equals 方法保证 key 不重复安全不允许空值整体效率低-哈希表无索引-遍历使用的是 Enumeration 列举
TreeMapMap有序key 不可重复,value 可重复,使用
hashCode 与 equals 方法保证 key 不重复
不安全key不可以,value可以TreeMap通常比HashMap、Hashtable要慢,
因为TreeMap底层采用红黑树来管理key-value。
整体效率低
1. 自然排序:TreeMap 的所有 key 必须实现 Comparable 接口,而且所有的 key 应该是同一个类的对象,否则会抛出ClassCastException。
2.定制排序:创建TreeMap时,传入一个 Comparator 对象,该对象负责对TreeMap中的所有key进行排序。
红黑树无索引需要基于key排序的场景-
LinkedHashMapMap有序(可分为插入顺序和访问顺序两种)key 不可重复,value 可重复,使用 hashCode() 与 equals() 方法保证 key 不重复不安全key不可以,value可以LinkedHashMap比HashMap慢一点,因为它需要链表来维护key-value的插入顺序。整体效率低-基于HashMap和双向链表来实现无索引当我们希望有顺序地去存储 key-value时,就需要使用 LinkedHashMap双向链表用来维护顺序
WeakHashMapMap无序,无法保证键值对的顺序key 不可重复,value 可重复,使用 hashCode 与 equals 方法保证 key 不重复不安全允许空值,key允许一个null,value允许多个null--哈希表(数组+链表)无索引适用于缓存的场景-
EnumMapMap无序,无法保证键值对的顺序key 不可重复,value 可重复不安全允许空值,key允许一个null,value允许多个null相比HashMap,EnumMap的性能和速度要快很多-数组有索引(通过ordinal方法取索引)--
IdentityHashMapMap无序,无法保证键值对的顺序key 可重复,value 可重复,使用 hashCode 与 equals 方法保证 key 不重复不安全允许空值,key允许一个null,value允许多个null速度要比HashMap快一点-哈希表(数组+链表)无索引比如序列化、深度复制、记录对象代理等场景;两个对象是同一个类型的对象,而且两个对象的数据完全相同,对于jvm来说,他们也是完全不同的,如果要用一个容器来记录这样的对象,就需要用 IdentityHashMapIdentityHashMap中key能重复,因为 key 比较的方法是 ==,所以若要存放两个相同的 key,就需要存放不同的地址
PropertiesMap无序,无法保证键值对的顺序key 不可重复,value 可重复,使用 hashCode 与 equals 方法保证 key 不重复不安全不允许存null--哈希表无索引配置文件Properties类表示一组持久的属性。 Properties可以保存到流中或从流中加载。 属性列表中的每个键及其对应的值都是一个字符串
TreeSetCollection有序不可重复,同样需要重写 hashCode 和 equals 方法,TreeSet 判断两个对象不相等的方式是两个对象通过 equals 方法返回 false,或者通过 compareTo 方法比较没有返回 0不安全不允许空值查找效率高,添加/删除效率低,整体效率高1.自然排序,使用 compareTo 方法来比较元
素之间大小关系,然后将元素按照
升序排列。2.定制排序,实现 Comparator
接口的compareTo 方法
红黑树,基于 TreeMap 实现无索引需要排序的场景只能添加同一种类型的对象
HashSetSet无序(即存取顺序不一致)不可重复,使用 hashCode() 与 equals() 方法保证 key 不重复不安全允许存null,只能存1个null具有良好的存取和查找性能,其性能通常都优于 TreeSet-哈希表(数组+链表),基于 HashMap 实现无索引需要快速查找的场景-
LinkedHashSetSet有序不可重复不安全允许空值LinkedHashSet 插入性能略低于 HashSet,但在迭代访问 Set 里的全部元素时有很好的性能-双向链表和哈希表,基于 LinkedHashMap 实现无索引-链表保证了元素的顺序与存储顺序一致,哈希表保证了元素的唯一性

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

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

相关文章

java nio教程_Java NIO教程

java nio教程1.简介 Java NIO是Java 1.4引入的一个库。 自从Java NIO推出以来,它提供了另一种方法来处理I / O和网络事务。 它被认为是Java网络和Java IO库的替代方法。 开发Java NIO的目的是使输入和输出的事务异步和非阻塞。 阻塞和非阻塞IO的概念将在后面的部分…

qq html制作,jquery学习练习:制作QQ简易聊天框

使用html( )获取和设置页面内容使用val( )获取聊天内容使用addClass( )为指定元素追加样式使用数组保存聊天人员头像和昵称使用随机函数获取聊天人员的头像和昵称在输入框中输入内容,单击“发送”按钮,显示聊天内容,使用addClass( )为聊天内容…

IntelliJ IDEA 删除了快捷键后,如何找回来?

文章目录修改冲突快捷键删除了快捷键,如何找回修改冲突快捷键 删除了快捷键,如何找回 如上图所示,如果你删除了【Restore Default Layout】的快捷键后,如何找回来进行重新设置呢? 你可以按组合键【Command ,】&…

移动端设置html的字体尺寸,移动端开发元素及字体尺寸适配基础知识

刚看了一篇真正教会你开发移动端页面的文章(二),文章写的很清楚,现总结下他的核心思想及自己所查阅的一些资料:假设设计稿是iPhone6(iPhone6设备像素为750px;设备像素比为2,即其适口尺寸为375px)上有200px的方块box&am…

气味识别应用_解决气味

气味识别应用有时,我们在代码库中可能会遇到一些巨大的if语句。 这些语句必须维护并一次又一次地更改相同的代码块。 在if语句检查变量是否属于某个值范围内的情况下,这也是常见的。 假设您有一个枚举 public enum FoodType {FRUIT,VEGETABLES,RED_MEA…

IntelliJ IDEA for Mac 文件结构侧边窗口/类文件内部结构(File Structure)

文章目录显示或者隐藏类中的属性信息显示或者隐藏类中的非公开信息显示或者隐藏类中的字段信息显示或者隐藏继承自父类的内容显示或者隐藏匿名内部类单击导航的开关始终选择打开的元素通过定义类型进行方法分组类内部结构的节点排序类内部结构窗口可以按组合键【Command 7】打…

java.awt.api_Java SE 11(18.9)中的API更新

java.awt.apiJava SE 11也被命名为18.9(基于使用发布年份和月份的新命名方案),预计将在9月的最后一周发布GA。 频繁发布新JDK版本的新方法是允许语言创建者引入新功能,并向开发人员社区更快地更新API。 通常,API更新不…

卡西欧82es计算机怎么玩游戏,卡西欧计算器fx82es-如何使用卡西欧fx-82es计算器计算矩阵 – 手机爱问...

2009-12-24有关于卡西欧计算器的问题卡西欧计算机中,坐标变换计算方法:如将极坐标中距离为2,角度为60度的点,转换为直角坐标,可参考方式:选定角度单位,如选定“DEG”即使用“度、分、秒”;输入距…

Java中,为什么子类的构造方法中必须调父类的构造方法?

1.有父才会有子,即便父类什么东西都没有,也必须调父类的构造方法,这样符合现实的生命传承关系,符合 Java 的面向对象和继承的思想 2.如果父类有一些变量,那么调用父类的构造方法,就可以通知 JVM 把父类加载…

java批处理 异常处理_Java批处理教程

java批处理 异常处理在当今世界,互联网已经改变了我们的生活方式,其主要原因之一是大部分日常琐事都使用互联网。 这导致大量数据可用于处理。 其中涉及大量数据的一些示例是处理工资单,银行对帐单,利息计算等。因此,…

html 按钮防止多次提交,HTML点击提交按钮两次

我最近添加了一个CSS3焦点样式到一个表单的元素(它垂直增长,给更多的空间来写)。然而,现在当用户点击提交按钮时,textarea会失去焦点(和缩小),但表单不会提交,用户必须再次点击提交。有没有解决这个问题的方法&#xf…

Java的子类可以继承父类的私有变量和私有方法吗?

答:实际上继承了。 父类的成员变量(包含私有变量)和成员方法地址(包含私有成员方法)都存放在子类对象中。父类的私有变量和私有方法虽然在子类对象中,但是对于子类对象而言是不可见的,无法直接…

html关于超链接的问题,关于超链接的一些问题

xhtml css页面制作过程中问题的解决方案,说是解决方案应该有点过了,充其量只不过是给刚刚开始学标准页面制作的朋友们的一些小建议,如 2018-04-14XHTML里面的img标记应该这样写:,这种写法也就是所谓的自关闭&#xff0…

java中无限大_Java 9中的无限集

java中无限大一套 甲Set是元素的集合&#xff0c;从而在任何给定的元件Set只出现一次。 更正式地说&#xff0c;集合不包含元素e1和e2对&#xff0c;因此e1.equals(e2) 。 我们可以像这样在Java 9中轻松创建Set &#xff1a; final Set<Integer> s Set.of(1, 2, 3); …

Java中父类的私有数据和静态数据在内存中是如何存储的?

1.父类的成员变量&#xff08;包含私有变量&#xff09;和成员方法地址&#xff08;包含私有成员方法&#xff09;都存放在子类对象中。父类的私有变量和私有方法虽然在子类对象中&#xff0c;但是对于子类对象而言是不可见的&#xff0c;无法直接访问和调用&#xff0c;必须通…

在计算机中 用户程序,在用户计算机上的万维网客户程序是()

摘要&#xff1a;修理需检后不测&#xff0c;户计户程行修即进应立理&#xff0c;修理自行解体铅封拆动。维网客注意简述计的基本及其R引原则要点物设。和鱼观察态的动水色&#xff0c;户计户程天早塘一养殖应每晚巡池塘次。...修理需检后不测&#xff0c;户计户程行修即进应立…

snmp与java集成_轻松地与Java完全集成

snmp与java集成这里是如何不使用SQL&#xff0c;HQL&#xff0c;PHP&#xff0c;ASP&#xff0c;HTML&#xff0c;CSS或Javascript而是使用Vaadin的UI层和Speedment Stream ORM完全依赖Java编写完整堆栈数据库Web应用程序的方法。 是否曾经想过快速创建连接到您现有数据库的We…

Java代码块的学习

普通代码块 在方法体中定义的代码块。 public static void main(String[] args) {{int i 20;System.out.println(i);}System.out.println(i); // 访问不到变量 i}构造代码块 1.在方法外定义的非静态的代码块 2.先于构造方法执行。实际是先执行父类构造方法&#xff0c;接着…

北大计算机专业考研难不难,北京大学考研有多难 难考的原因是什么

每年都有很多学生在本科毕业后选择考研&#xff0c;北京大学作为我国顶尖名校&#xff0c;想通过考研进入这所大学的人更是多的数不过来。那么&#xff0c;北京大学考研有多难呢&#xff1f;北京大学考研很难吗首先清华北大的难度在于这个学校的综合实力和业内地位&#xff0c;…