Java工具库Guava的区间(范围Range)的构建、区间运算、查询运算、关系运算(包含、相连、交集、并集)的使用示例
admin
2024-02-08 14:41:53
0

场景

Java核心工具库Guava介绍以及Optional和Preconditions使用进行非空和数据校验:

Java核心工具库Guava介绍以及Optional和Preconditions使用进行非空和数据校验_霸道流氓气质的博客-CSDN博客

Java工具库Guava的不可变集合和新集合类型Multiset、Multimap、BiMap、RangeSet、RangeMap等的使用示例:

Java工具库Guava的不可变集合和新集合类型Multiset、Multimap、BiMap、RangeSet、RangeMap等的使用示例_霸道流氓气质的博客-CSDN博客

在上面了解了Guava的基本使用以及在使用RangeMap时对范围Range有过初步的使用。

下面看其他用法示例

注:

博客:
霸道流氓气质的博客_CSDN博客-C#,架构之路,SpringBoot领域博主
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

Range的构建

Guava 中的 Range 要求上端点不能小于下端点。上下端点有可能是相等的,

但要求区间是闭区间或半开半闭区间(至少有一个端点是包含在区间中的),比如:
 [a..a]:单元素区间
 [a..a); (a..a]:空区间,但它们是有效的
 (a..a):无效区间

区间实例可以由Range类的静态方法获取

        Range closed = Range.closed(1, 5);System.out.println(closed);//[1..5]Range integerRange = Range.lessThan(4);System.out.println(integerRange);//(-∞..4)

其他方法还有

        //(a..b)  open(C, C)//[a..b]  closed(C, C)//[a..b)  closedOpen(C, C)//(a..b]  openClosed(C, C)//(a..+∞)  greaterThan(C)//[a..+∞)  atLeast(C)//(-∞..b)  lessThan(C)//(-∞..b]  atMost(C)//(-∞..+∞) all()

此外,也可以明确地指定边界类型来构造区间,这里的BoundType是一个枚举类型,包含 CLOSED 和 OPEN 两个值。

有界区间  range(C, BoundType, C, BoundType)
无上界区间:((a..+∞) 或[a..+∞))  downTo(C, BoundType)
无下界区间:((-∞..b) 或(-∞..b])  upTo(C, BoundType)

        System.out.println(Range.downTo(3, BoundType.CLOSED));//[3..+∞)System.out.println(Range.downTo(3, BoundType.OPEN));//(3..+∞)System.out.println(Range.upTo(3, BoundType.CLOSED));//(-∞..3]System.out.println(Range.upTo(3, BoundType.OPEN));//(-∞..3)

区间运算

Range 的基本运算是它的 contains(C),它用来区间判断是否包含某个值

        boolean contains = Range.closed(1, 9).contains(3);System.out.println(contains);//true

查询运算

Range 类提供了以下方法来 查看区间的端点:
hasLowerBound()和hasUpperBound():判断区间是否有特定边界,或是无限的;
lowerBoundType()和upperBoundType():返回区间边界类型,CLOSED 或 OPEN;如果区间没有对应的边界,抛出 IllegalStateException
lowerEndpoint()和upperEndpoint():返回区间的端点值;如果区间没有对应的边界,抛出 IllegalStateException;
isEmpty():判断是否为空区间。

        Range.closedOpen(4, 4).isEmpty(); // returns trueRange.openClosed(4, 4).isEmpty(); // returns trueRange.closed(4, 4).isEmpty(); // returns falseRange.open(4, 4).isEmpty(); // Range.open throws IllegalArgumentExceptionRange.closed(3, 10).lowerEndpoint(); // returns 3Range.open(3, 10).lowerEndpoint(); // returns 3Range.closed(3, 10).lowerBoundType(); // returns CLOSEDRange.open(3, 10).upperBoundType(); // returns OPEN

关系运算-包含

区间之间的最基本关系就是包含[encloses(Range)]:

如果内区间的边界没有超出外区间的边界,则外区间包含内区间。包含判断的结果完全取决于区间端点的比较

        // [3..6] 包含[4..5] ;System.out.println(Range.closed(3,6).encloses(Range.closed(4,5)));//true// (3..6) 包含(3..6) ;System.out.println(Range.open(3,6).encloses(Range.open(3,6)));//true// [3..6] 包含[4..4),虽然后者是空区间;System.out.println(Range.closed(3,6).encloses(Range.closedOpen(4,4)));//true// (3..6]不 包含[3..6] ;System.out.println(Range.openClosed(3,6).encloses(Range.closed(3,6)));//false// [4..5]不 包含(3..6),虽然前者包含了后者的所有值,离散域[discrete domains]可以解决这个问题System.out.println(Range.closed(4,5).encloses(Range.open(3,6)));//false

关系运算-相连

Range.isConnected(Range)判断区间是否是相连的。具体来说,isConnected 测试是否有区间同时包含于这两个区间,这等同于数学上的定义”两个区间的并集是连续集合的形式”(空区间的特殊情况除外)。

        System.out.println(Range.closed(3,5).isConnected(Range.open(5,10)));//trueSystem.out.println(Range.closed(0,9).isConnected(Range.closed(3,4)));//trueSystem.out.println(Range.closed(0,5).isConnected(Range.closed(3,9)));//trueSystem.out.println(Range.open(3,5).isConnected(Range.open(5,10)));//falseSystem.out.println(Range.closed(1,5).isConnected(Range.closed(6,10)));//false

关系运算-交集

Range.intersection(Range)返回两个区间的交集:既包含于第一个区间,又包含于另一个区间的最大区间。

当且仅当两个区间是相连的,它们才有交集。如果两个区间没有交集,该方法将抛出 IllegalArgumentException

System.out.println(Range.closed(3,5).intersection(Range.closed(4,6)));//[4..5]

关系运算-并集

Range.span(Range)返回”同时包括两个区间的最小区间”,如果两个区间相连,那就是它们的并集。

        System.out.println(Range.closed(3,5).span(Range.closed(7,9)));//[3..9]System.out.println(Range.closed(3,5).span(Range.closed(4,8)));//[3..8]

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...