【Groovy】集合遍历 ( 使用集合的 findAll 方法查找集合中符合匹配条件的所有元素 | 代码示例 )

简介: 【Groovy】集合遍历 ( 使用集合的 findAll 方法查找集合中符合匹配条件的所有元素 | 代码示例 )

文章目录

一、使用集合的 findAll 方法查找集合中符合匹配条件的所有元素

1、闭包中使用 == 作为 findAll 方法的查找匹配条件

2、闭包中使用 is 作为 findAll 方法的查找匹配条件

3、闭包中使用 true 作为 findAll 方法的查找匹配条件

二、完整代码示例





一、使用集合的 findAll 方法查找集合中符合匹配条件的所有元素


在上一篇博客 【Groovy】集合遍历 ( 使用集合的 find 方法查找集合元素 | 闭包中使用 == 作为查找匹配条件 | 闭包中使用 is 作为查找匹配条件 | 闭包使用 true 作为条件 | 代码示例 ) 中 , 介绍了使用 find 方法 , 获取集合中第一个符合 闭包匹配条件的元素 ;



使用集合的 findAll 方法 , 可以 获取 集合 中 所有 符合 闭包匹配条件的元素 , 这些元素将使用一个新的集合盛放 , findAll 方法的返回值就是返回该符合 匹配条件 的元素 ;



集合的 findAll 方法原型 :


 

/**
     * 查找与关闭条件匹配的所有值。
     * <pre class="groovyTestCase">assert [2,4] == [1,2,3,4].findAll { it % 2 == 0 }</pre>
     *
     * @param self    集合
     * @param closure 闭包条件
     * @return 符合条件匹配的新的子集合
     * @since 1.5.6
     */
    public static <T> Collection<T> findAll(Collection<T> self, @ClosureParams(FirstParam.FirstGenericType.class) Closure closure) {
        Collection<T> answer = createSimilarCollection(self);
        Iterator<T> iter = self.iterator();
        return findAll(closure, answer, iter);
    }



1、闭包中使用 == 作为 findAll 方法的查找匹配条件


在集合的 findAll 方法中 , 闭包中使用 == 作为查找匹配条件 , 查找集合中值为 “1” 的元素 , 此处的 == 等价于 Java 中调用 String 的 equals 方法 , 不是比较地址 ;



代码示例 :


   

// I. 闭包中使用 == 作为查找匹配条件
        def findCollectionResult = list.findAll{
            // 查找集合中值为 "1" 的元素
            // 此处的 == 等价于 Java 中调用 String 的 equals 方法 , 不是比较地址
            it == "1"
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [1, 1]

     

执行结果 :


[1, 2, 3, 1, 2, 3]
[1, 1]



2、闭包中使用 is 作为 findAll 方法的查找匹配条件


在集合的 findAll 方法中 , 闭包中使用 is 作为查找匹配条件 , 查找集合中与 “3” 对象相同地址的元素 , 此处的 is 方法等价于调用 String 的 == 运算 , 不是比较值 ;



代码示例 :


     

// II. 闭包中使用 is 作为查找匹配条件
        findCollectionResult = list.findAll{
            // 查找集合中与 "3" 对象相同地址的元素
            // 此处的 is 方法等价于调用 String 的 == 运算 , 不是比较值
            it.is("3")
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [3, 3]
        println findCollectionResult



执行结果 :


[1, 2, 3, 1, 2, 3]
[3, 3]


3、闭包中使用 true 作为 findAll 方法的查找匹配条件


在集合的 findAll 方法中 , 闭包中使用 true 作为查找匹配条件 , 查找集合中不为空的元素 , 此处返回第一个不为空的元素 ;



代码示例 :


   

// III. 闭包中使用 true 作为条件 , 返回第一个不为空的元素
        findCollectionResult = list.findAll{
            // 返回第一个不为空的元素
            true
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [1, 2, 3, 1, 2, 3]
        println findCollectionResult



执行结果 :


[1, 2, 3, 1, 2, 3]
[1, 2, 3, 1, 2, 3]






二、完整代码示例


完整代码示例 :


class Test {
    static void main(args) {
        // 为 ArrayList 设置初始值
        def list = ["1", "2", "3", "1", "2", "3"]
        // I. 闭包中使用 == 作为查找匹配条件
        def findCollectionResult = list.findAll{
            // 查找集合中值为 "1" 的元素
            // 此处的 == 等价于 Java 中调用 String 的 equals 方法 , 不是比较地址
            it == "1"
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [1, 1]
        println findCollectionResult
        // II. 闭包中使用 is 作为查找匹配条件
        findCollectionResult = list.findAll{
            // 查找集合中与 "3" 对象相同地址的元素
            // 此处的 is 方法等价于调用 String 的 == 运算 , 不是比较值
            it.is("3")
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [3, 3]
        println findCollectionResult
        // III. 闭包中使用 true 作为条件 , 返回第一个不为空的元素
        findCollectionResult = list.findAll{
            // 返回第一个不为空的元素
            true
        }
        // 打印 [1, 2, 3, 1, 2, 3]
        println list
        // 打印 [1, 2, 3, 1, 2, 3]
        println findCollectionResult
    }
}


执行结果 :


[1, 2, 3, 1, 2, 3]
[1, 1]
[1, 2, 3, 1, 2, 3]
[3, 3]
[1, 2, 3, 1, 2, 3]
[1, 2, 3, 1, 2, 3]

image.png

目录
相关文章
|
Android开发
mac下配置adb环境变量
在终端中输入adb命令时,会提示 command not found ,这是是因为mac电脑下没有配置Android环境变量或者环境变量配置错误。
|
监控 Java 索引
ES 生产中10个常见参数阈值(默认最大值)操作及优化解决方案
ES 生产中10个常见参数阈值(默认最大值)操作及优化解决方案
ES 生产中10个常见参数阈值(默认最大值)操作及优化解决方案
|
2月前
|
消息中间件 人工智能 Cloud Native
下单丝滑,大促自由:古茗奶茶背后的云原生力量
在新茶饮行业,每一次刷屏级的营销活动,每一杯奶茶的“丝滑”下单,背后都是对数字化基座的严峻考验,是一场应对瞬时高并发流量的技术硬仗。作为拥有超万家门店的行业头部品牌,古茗不仅要支撑海量日常订单,更需在“周三会员日”等大促时刻,从容应对流量陡增,确保系统稳如磐石。面对高并发下的极速响应与弹性需求,古茗如何实现“大促自由”?本期《云故事探索》栏目走进古茗,揭秘支撑新茶饮“万店时代”的云原生力量。
464 42
|
8月前
|
机器学习/深度学习 人工智能 搜索推荐
Thinking Machines Lab最新研究结果如何复现?On-Policy Distillation让训练成本直降10倍
Thinking Machines Lab提出On-Policy Distillation技术,让小模型高效继承大模型能力。相比传统强化学习,训练成本降低90%,效率提升十倍,支持本地部署、降低成本与延迟。结合vLLM加速与独立DeepSpeed配置,MS-SWIFT框架实现开箱即用的高效蒸馏训练,助力轻量模型具备“会思考、能纠错、可进化”的智能。
1869 10
|
8月前
|
SQL Java 数据库连接
MyBatisPlus
MyBatisPlus是MyBatis的增强版,致力于简化Java持久层开发。它在保留MyBatis灵活性的基础上,通过自动化CRUD、优雅的条件构造器、分页插件等特性,大幅提升开发效率。其“半自动化”设计平衡了便捷与可控,完美融合Spring Boot生态,支持多种数据库与现代架构,兼具性能优化与团队协作优势,是企业级开发的智慧之选。(238字)
|
11月前
|
数据采集 存储 人工智能
从“看得见”到“会调参”:智能化工艺参数调优系统如何突破传统局限?
本文由产品专家三桥君介绍了智能化工艺参数调优系统的关键技术与应用价值。该系统通过现场视频采集、图像识别模块获取实时数据,结合历史经验数字化形成的向量数据库,利用大模型进行智能推理输出最优参数建议,并由智能体执行调整。系统实现了从数据感知到智能调参的闭环控制,显著提升了工艺参数优化的准确性和生产效率,突破了传统经验调参的局限性。
638 0
|
数据采集 存储 监控
Python 原生爬虫教程:网络爬虫的基本概念和认知
网络爬虫是一种自动抓取互联网信息的程序,广泛应用于搜索引擎、数据采集、新闻聚合和价格监控等领域。其工作流程包括 URL 调度、HTTP 请求、页面下载、解析、数据存储及新 URL 发现。Python 因其丰富的库(如 requests、BeautifulSoup、Scrapy)和简洁语法成为爬虫开发的首选语言。然而,在使用爬虫时需注意法律与道德问题,例如遵守 robots.txt 规则、控制请求频率以及合法使用数据,以确保爬虫技术健康有序发展。
1597 31
|
人工智能 自然语言处理 安全
💻 Codex 来了:OpenAI 推出多任务软件工程 AI 代理,开发者工作方式将被重塑?
Codex 是 OpenAI 推出的一款云端智能开发代理,基于优化后的 Codex-1 模型,能够执行从代码编写、Bug 修复到 PR 提交的完整工程任务。通过 ChatGPT 的界面,用户可向 Codex 分配任务,它将在独立沙盒中运行并返回结果。Codex 支持多任务异步处理,遵循项目规范(AGENTS.md),并生成日志与测试报告以确保透明性。作为“AI 参与式开发”的里程碑,Codex 不仅提升效率,还可能重塑开发者角色,使他们从具体编码转向指导 AI 完成任务,推动软件工程进入意图驱动的新时代。
1918 16
|
SQL Java 数据库连接
【潜意识Java】深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
深入理解MyBatis的Mapper层,以及让数据访问更高效的详细分析
2997 1
|
机器学习/深度学习 编解码 自动驾驶
全新ViT Backbone | PLG-ViT 同时具有并行局部和全局自注意力的轻量化视觉Transformer
全新ViT Backbone | PLG-ViT 同时具有并行局部和全局自注意力的轻量化视觉Transformer
769 0