首页 > 编程语言 >你知道Java21中的顺序集合吗?

你知道Java21中的顺序集合吗?

时间:2023-10-28 10:01:42浏览次数:39  
标签:Java21 顺序 接口 类型 SequencedCollection SequencedMap key 集合

大家好,我是老七,点个关注吧,将持续更新更多精彩内容!

你知道Java21中的顺序集合吗?_API

在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 类型添加更多便利。虽然与其他语言相比可能不够简洁和全面,但我相信会越来越完善的。


如果各位觉得老七的文章还不错的话,麻烦大家动动小手,

点赞、关注、转发走一波!!

有任何问题可以评论区留言或者私信我,我必将知无不言言无不尽!

标签:Java21,顺序,接口,类型,SequencedCollection,SequencedMap,key,集合
From: https://blog.51cto.com/u_16277888/8067423

相关文章

  • json 对象属性的输出顺序测试,fastJson 有序,jackson,gson无序(需代码中人工按约定来编码
    json对象属性的输出顺序测试,fastJson有序,jackson,gson无序(需代码中人工按约定来编码)接口数据签名规则fastJson会根据对象的字段的首字母来排序。而jackson,gson是根据对象的类中定义的属性的代码中的先后顺序输出。不会排序。针对业务场景需要对接口中对象存在集合列表等,需要......
  • 探究tf卡(内存卡)在音频播放器中的播放顺序【指金正音频播放器之类的设备】
    首先,【同一个文件路径下的】音频文件,肯定是按复制进tf卡(小卡)的时间顺序,来确定播放顺序的;与音频文件的名字叫什么毫无关系,即使名字前面加序号也毫无用处。 【在同一路径下的】音频文件和文件夹之间,优先播放音频文件,然后是文件夹。 【在同一路径下的】文件夹和文件夹之间,是按......
  • 数据结构-顺序表
    一、概念1.顺序存储顺序存储结构,是指用一段地址连续的存储单元依次存储线性表的数据元素2.存储方式在编程语言中,用一维数组来实现顺序存储结构,在C语言中,把第一个数据元素存储到下标为0的位置中,把第2个数据元素存储到下标为1的位置中,以此类推。3.长度和容量数组的长度指的是数组......
  • 获取Java21所有启动参数及默认值
    各版本获取启动参数命令:java-XX:+PrintFlagsFinal-version>jvm_flags.txt所有参数:[Globalflags]intActiveProcessorCount=-1{product}{default}uintxAdaptiveSizeDecrementScaleFactor......
  • 【Java集合】了解集合的框架体系结构及常用实现类,从入门到精通!
    前言通过Java基础的学习,我们掌握了主要的Java语言基本的语法,同时了解学习了Java语言的核心-面向对象编程思想。从集合框架开始,也就是进入了java这些基础知识及面向对象思想进入实际应用编码的过程,通过jdk中集合这部分代码的阅读学习,就能发现这一点。本计划在这篇中把框架体系和......
  • 过滤器执行顺序
    请求进入网关会碰到三类过滤器:当前路由的过滤器、DefaultFilter、GlobalFilter请求路由后,会将当前路由过滤器和DefaultFilter、GlobalFilter,合并到一个过滤器链(集合)中,排序后依次执行每个过滤器:排序的规则是什么呢?每一个过滤器都必须指定一个int类型的order值,order值越小,优先......
  • pytest设置随机执行case 顺序
    1.安装包  pytest-randomly(这个能成)2. 在class上设置  @pytest.mark.random_orderclassTestMulit:3.设置每条case执行的次数@pytest.mark.repeat(set_ratio.multiple_01)#设置该条case执行的次数这个次数顺序也是混合到总数中的随机执行@allure.title......
  • vue学习笔记之执行顺序
       vue文件加载顺序:index.html>app.vue>main.js     加载顺序详情:执行index.html(index.html中id为app的div标签是一个挂载点,之后我们的Vue根实例就会挂载到该挂载点上)执行main.jsmain.js找到实例挂载app.vue文件,将index.html的挂载的内容显示出来(用app.vue的template......
  • 由于正则表达式的匹配顺序,这个例子可能并不会按照你期望的方式工作。正则表达式会从左
    在Python中,你可以使用re模块的sub函数来替换字符串中的特定字符或字符串。以下是一个示例,它将字符串中的'a'、'b'和'ab'替换为'c':importres='abracadabra's=re.sub('a|b|ab','c',s)print(s)#打印替换后的字符串在这个例子中,'a|b|ab'是一个正则表......
  • java MAP集合
    javaMAP集合map集合的特点有哪些?map集合是无序的,键值对,建不能重复,值可以重复,集合中的键可以为空如何给map集合赋值?可以调用map.put()方法,进行赋值(注意!键不可以重复)如何获取到map集合的值?可以调用map.get()方法,可以通过键获取值运行结果如何遍历map集合?便利map集合的......