你知道Java21中的顺序集合吗? 你知道java21中的顺序集合吗?举例说明
yuyutoo 2024-10-12 01:24 3 浏览 0 评论
在Java 21中,处理集合的方式得到了改进,因为三个新的接口已经融入了现有的类型层次结构。这些顺序集合为我们提供了一个统一的API来访问第一个和最后一个元素,并以相反的顺序处理集合。
为了更好地理解顺序集合是什么,让我们回顾一下集合之前的样子。
Java集合框架
在Java 1.2中引入的Collections Framework,为我们提供了许多接口和类来代表一组对象。这个统一的API具有许多优点,比如使不相关的API之间具有“标准化”的集合类型互操作性,因此促进代码重用。
十几个接口为底层通用和专用实现提供了一个很好的抽象,包括并发环境的实现。尽管不同集合类型的类型层次结构和功能经过精心设计,提供了很大的灵活性和功能,但直到现在才出现了一个缺失的方面……
从前到后,从后到前
获取集合的第一个或最后一个元素是一个非常常见的任务,通常这样做并不漂亮……我敢肯定,正在阅读这篇文章的每个人都曾经无数次地这样做过:
List items = ...; String first = items.get(0); String last = items.get(items.size() - 1);
一些集合类型支持直接访问第一个和最后一个元素,但目前还没有一个共同的接口,也没有一个通用的API(尚不支持):
Type | First Element | Last Element --------- | ----------------- | -------------------------- List | list.get(0) | list.get(list.size() - 1) Deque | deque.getFirst() | deque.getLast() SortedSet | sortedSet.first() | sortedSet.last()
每一个基于Collection的类型都可以很容易地从前往后遍历,因为它是Iterator的后代。这样,我们就可以使用for-each循环、Stream管道,并通过调用toArray()创建任何集合的数组。然而,对于反向遍历,即从后往前,目前还没有简单的方法或技巧。这意味着,例如,如果我们必须处理一个LinkedHashSet,我们必须遍历整个集合才能得到最后一个元素。
直到Java 21顺序集合的出现!
序贯集合类型
JEP 431在集合框架的类型层次结构中引入了三个新的接口,位置十分关键。像过去几年中的许多其他特性一样,这些接口通过默认方法注入新的功能,因此一切仍然保持向后兼容,除非我们想要更特殊的实现,否则没有人需要自己实现这些方法。
这三个新的序贯接口是:
SequencedCollection<E> extends Collection<E>
SequencedSet<E> extends SequencedCollection<E>, Set<E>
SequencedMap<K, V> extends Map<K, V>
SequencedMap
SequencedMap<K, V>接口看起来就像你期望的那样,特别是由于除了reversed()之外的所有方法都是从已有的Deque<E>类型中提升而来的,以提供一个已知且统一的API:
interface SequencedMap<K, V> extends Map<K, V> { // NEW METHOD SequencedMap<K, V> reversed(); // PROMOTED METHODS FROM Deque<E> void putFirst(K key, V value); void putLast(K key, V value); V getFirst(K key); V getLast(K key); V removeFirst(K key); V removeLast(K key); }
add...和remove...方法是可选的,并在其默认实现中抛出UnsupportedOperationException以支持不可修改的集合。get...方法的行为类似于其兄弟,在集合为空的情况下抛出NoSuchElementException。
SequencedSet
SequencedSet<E>基于SequencedCollection<E>,但具有reversed()方法的协变覆盖:
interface SequencedSet<E> extends SequencedCollection<E>, Set<E> { SequencedSet<E> reversed(); }
之前提到的行为仍然有效,因为SequencedCollection<E>的默认实现中没有覆盖任何方法。
SequencedMap<K, V>
SequencedMap<K, V>是基于SequencedCollection<E>但具有协变覆盖的返回类型:
interface SequencedMap<K, V> extends SequencedCollection<Map.Entry<K, V>>, Map<K, V> { SequencedMap<K, V> reversed(); }
之前提到的行为仍然有效,因为SequencedCollection<E>的默认实现中没有覆盖任何方法。尽管在概念上不同于其他集合作为基于键值对的数据结构,但是采用顺序化方法仍然可以获得很多好处。与 SequencedCollection<E> 类似, SequencedMap<K, V> 的类型也是从预先存在的类型中获得其功能,在此为 NavigableMap<K, V>:
interface SequencedMap<K,V extends Map<K,V>> { // NEW METHODS SequencedMap<K,V> reversed(); SequencedSet<K> sequencedKeySet(); SequencedCollection<V> sequencedValues(); SequencedSet<Entry<K,V>> sequencedEntrySet(); V putFirst(K key, V value); V putLast(K key, V value); // PROMOTED METHODS FROM NavigableMap<K, V> Entry<K, V> firstEntry(); Entry<K, V> lastEntry(); Entry<K, V> pollFirstEntry(); Entry<K, V> pollLastEntry(); }
有趣的是,有两个促进的 poll... 方法,因为它们让我们可以轻松地访问第一个或最后一个条目,并且一次性删除它。
扩展Java的集合框架
如前所述,这三种新类型被改造后直接集成到现有的类型层次结构中,以在不破坏任何兼容性的情况下为我们提供所有新的好东西:
整个类型层次结构中的 Sequenced Collections 类型(来源:JEP 431)
基于 Collection 的类型更改如下:
List 和Deque 现在将 SequencedCollection 作为它们的直接超接口。
SortedSet 现在直接从 SequencedSet 派生。以下是翻译后的内容:
现在,LinkedHashSet 实现了 SequencedSet 接口,并额外实现了 SequencedSet。
对于 Map 的更改并不多,SequenceMap 类型直接位于 Map 之下,而其上方是 SorterMap 的新超接口和 LinkedHashMap 实现的额外接口。
为了与 Collections Framework 的总体主题相匹配,Collections 上还有三个新的 static 帮助方法:
Collections.unmodifiableSequencedCollection(sequencedCollection)
Collections.unmodifiableSequencedSet(sequencedSet)
Collections.unmodifiableSequencedMap(sequencedMap)
结论:
我认为,在 Java 中引入明确定义的元素顺序和统一的 API 是一项受欢迎的改进。它将为开发人员提供更直接的方式来简化常见的集合任务,并逐步为 Java 类型添加更多便利。虽然与其他语言相比可能不够简洁和全面,但我相信会越来越完善的。
如果各位觉得老七的文章还不错的话,麻烦大家动动小手,
点赞、关注、转发走一波!!
有任何问题可以评论区留言或者私信我,我必将知无不言言无不尽!
相关推荐
- 史上最全的浏览器兼容性问题和解决方案
-
微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...
-
- 平面设计基础知识_平面设计基础知识实验收获与总结
-
CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...
-
2025-02-21 16:01 yuyutoo
- 写作排版简单三步就行-工具篇_作文排版模板
-
和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...
- 写一个2048的游戏_2048小游戏功能实现
-
1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...
- 今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……
-
最近的天气暖和得让很多小伙伴们喊“热”!!! 昨天的气温到底升得有多高呢?你家有没有榜上有名?...
- CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式
-
之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...
- 你的自我界限够强大吗?_你的自我界限够强大吗英文
-
我的结果:A、该设立新的界限...
- 行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?
-
行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...
-
- 让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
-
去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...
-
2025-02-21 16:00 yuyutoo
- 今年国家综合性消防救援队伍计划招录消防员15000名
-
记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...
- 一起盘点最新 Chrome v133 的5大主流特性 ?
-
1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...
- 竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使
-
style="text-align:center;"data-mce-style="text-align:...
- 学物理能做什么?_学物理能做什么 卢昌海
-
作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...
-
- 你不知道的关于这只眯眼兔的6个小秘密
-
在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...
-
2025-02-21 16:00 yuyutoo
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)