java 8 集合分组_Java 8:按集合分组

java 8 集合分组

在继续阅读Venkat Subramaniam的“ Java函数式编程 ”时,我到达了介绍Stream#collect函数的那部分。

我们想收集一个人,按年龄分组并返回一张方便的地图(年龄->人的名字)。

要刷新,这是Person类的样子:

static class Person {private String name;private int age;Person(String name, int age) {this.name = name;this.age = age;}@Overridepublic String toString() {return String.format("Person{name='%s', age=%d}", name, age);}
}

我们可以用Java 8编写以下代码来获取按年龄分组的人的名字的地图:

Stream<Person> people = Stream.of(new Person("Paul", 24), new Person("Mark", 30), new Person("Will", 28));
Map<Integer, List<String>> peopleByAge = people.collect(groupingBy(p -> p.age, mapping((Person p) -> p.name, toList())));
System.out.println(peopleByAge);
{24=[Paul], 28=[Will], 30=[Mark]}

我们正在集合上运行“收集”功能,并在进行时按“年龄”属性进行分组,并对人员姓名而不是人员本身进行分组。

这与您在Ruby中所做的稍有不同,在Ruby中您可以调用一个“ group_by”函数:

> people = [ {:name => "Paul", :age => 24}, {:name => "Mark", :age => 30}, {:name => "Will", :age => 28}]
> people.group_by { |p| p[:age] }
=> {24=>[{:name=>"Paul", :age=>24}], 30=>[{:name=>"Mark", :age=>30}], 28=>[{:name=>"Will", :age=>28}]}

这会向我们提供按年龄分组的人员列表,但我们需要应用其他“地图”操作来将其更改为姓名列表:

> people.group_by { |p| p[:age] }.map { |k,v| [k, v.map { |person| person[:name] } ] }
=> [[24, ["Paul"]], [30, ["Mark"]], [28, ["Will"]]]

在这个阶段,我们有一个(年龄,名字)对的数组,但是幸运的是Ruby 2.1.0有一个函数“ to_h”,我们可以调用它来再次返回哈希:

> people.group_by { |p| p[:age] }.map { |k,v| [k, v.map { |person| person[:name] } ] }.to_h
=> {24=>["Paul"], 30=>["Mark"], 28=>["Will"]}

如果要在对集合执行归约操作时遵循Java按属性分组的方法,则将具有以下内容:

> people.reduce({}) { |acc, item| acc[item[:age]] ||=[]; acc[item[:age]] << item[:name]; acc }
=> {24=>["Paul"], 30=>["Mark"], 28=>["Will"]}

如果我们使用Clojure,则可能会得到如下所示的结果:

(def people[{:name "Paul", :age 24} {:name "Mark", :age 30} {:name "Will", :age 28}])> (reduce (fn [acc [k v]] (assoc-in acc [k] (map :name v))) {} (group-by :age people))
{28 ("Will"), 30 ("Mark"), 24 ("Paul")}

我以为Java版本从一开始看起来有点怪异,但是用其他几种语言解决了这个问题,实际上还不错。

最好知道是否有更好的方法来使用Ruby / Clojure!

参考: Java 8:通过 Mark Needham博客博客的JCG合作伙伴 Mark Needham的收藏进行分组 。

翻译自: https://www.javacodegeeks.com/2014/02/java-8-group-by-with-collections.html

java 8 集合分组

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

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

相关文章

请编写一个php程序,(笔试题)php练习笔试题(一) 编写程序(请任选两题)

简答题1.写出5个以上你所知道的常用的Linux命令和它的功能cat&#xff0c;显示文件内容。cd&#xff0c;改变目录路径。cp&#xff0c;复制文件。find&#xff0c;查找文件。grep&#xff0c;搜索、过滤信息。ls&#xff0c;列出目录信息。more&#xff0c;分页显示。rm&#x…

python str translate,str.translate() --文本过滤和处理

问题: 想清除整个范围的字符&#xff0c;或者去掉音符1、使用str.translate()s python\fis\tawesome\r\n# 第一步是清理空格&#xff0c;可以先建立一个小型的转换表&#xff0c;然后使用reanslate()方法remap {ord(\t): ,ord(\f): ,ord(\r): None}a s.translate(remap)aO…

MicroProfile 2.2 BOM导入支持

MicroProfile 2.2刚刚发布&#xff0c;其中包含对Fault Tolerance&#xff0c;Open Tracing&#xff0c;Open API和Rest Client API的更新。 自2.2版以来&#xff0c;还支持使用BOM&#xff08;物料清单&#xff09;依赖项导入。 通过这种方法&#xff0c;我们可以在dependenc…

php内容缓存输出,PHP使用缓存即时输出内容(output buffering)的方法

PHP使用缓存即时输出内容(output buffering)的方法PHP使用缓存即时输出内容(output buffering)的方法。分享给大家供大家参考。具体如下&#xff1a;$buffer ini_get(output_buffering);echo str_repeat( ,$buffer1); //防止浏览器缓存ob_end_flush(); //关闭缓存for( $i1; $i…

继承能够访问父类私有字段_在单元测试中访问私有字段

继承能够访问父类私有字段首先&#xff0c;让我大声说一下&#xff0c;您需要将代码设计为可测试的&#xff0c;以便通过公共方法测试私有字段。 但是&#xff0c;&#xff08;“ buts”是人们仍在编程而不是计算机本身的原因&#xff0c;所以在这里很高兴&#xff09;有时您想…

php模拟论坛,模仿OSO的论坛(二)

模仿OSO的论坛(二)2006-10-09 00:00:00 作者&#xff1a;模仿OSO的论坛(二)read.php(用来显示相关主题内容)疑难问题主 题&#xff1a;color#993333>include "connect.inc.php";$query "select * from guestbook where id".$theme_id;$res mysql_quer…

甲骨文函数初探

我非常高兴有机会通过Cloud Native Limited Availability Program来测试Oracle功能。 去年&#xff0c;当我上次尝试在Oracle Groundbreaker APAC巡回赛中在Oracle Cloud中运行无服务器功能时&#xff0c;有两种选择。 您可以在虚拟机中运行我自己的Fn服务器&#xff0c;也可以…

oracle 邻接模型,【原创】MySQL 模拟Oracle邻接模型树形处理

数据库对层次结构的处理模型有好多种&#xff0c;可以根据自己的需求来设计模型&#xff0c;当然最简单的也是最容易设计的模型就是所谓的邻接模型。在这方面&#xff0c;其他数据库比如Oracle提数据库对层次结构的处理模型有好多种&#xff0c;可以根据自己的需求来设计模型&a…

json字符串导入oracle,如何在Oracle中将JSON字符串转换为JSON

我需要在Oracle查询中将JSON字符串转换为JSON。示例字符串&#xff1a;{"1":{"qid":1,"aid":1,"a":"Yes","isdyn":0},"2":{"qid":2,"aid":7,"a":"sdfbsjkb",&…

spring roo_使用Spring Roo进行概念验证

spring roo在Keyhole工作期间&#xff0c;我参与了许多项目&#xff0c;其中客户要求我们重写旧系统&#xff0c;同时保留其现有数据库。 有时&#xff0c;它有助于快速演示如何使用当前技术来简化开发&#xff0c;测试和维护其代码。 我发现可以创建一个快速示例&#xff08;…

【渝粤教育】电大中专药物分析技术基础作业 题库

1.《中国药典》规定“称定”时&#xff0c;指称取重量应准确至所取重量的 A.10% B.1.95&#xff5e;2.05g C.百分之一 D.1.5&#xff5e;2.5g E.千分之一 错误 正确答案&#xff1a;左边查询 学生答案&#xff1a;未作答 2.2℃&#xff5e;10℃指 A.密闭 B.密封 C.阴凉处 D.冷处…

oracle虚拟机怎么装系统,Virtualbox怎么安装系统 VirtualBox虚拟机安装Win8系统教程 (3)...

三、对新建的虚拟机做重要的设定&#xff1a;1、在Oracle VM VirtualBox里面点击下刚才建好的虚拟机&#xff0c;然后点下上面的黄色图标“设置”&#xff0c;或者右键菜单里面点击设置也可以(快捷键是CtrlS)Oracle VM VirtualBox虚拟机设置2、在出来的设置页面里面&#xff0c…

JDK 12的Files.mismatch方法

JDK 12向Files类引入了一种新方法。 方法Files.mismatch(Path,Path)已通过JDK-8202302引入JDK 12&#xff0c;并在JDK 12 Early Access Build 20 &#xff08;支持新{systemProperty} Javadoc标记的相同早期访问版本&#xff09;中可用 。 JDK-8202302 [“用于比较文件的&…

【渝粤教育】电大中专计算机网络基础 (2)作业 题库

1通信中产生和发送信息的一端叫做&#xff08;&#xff09;。 A信源 B信宿 C信道 D噪声 正确 正确答案&#xff1a;左边查询 学生答案&#xff1a;A 2通信中接收信息的一端叫做&#xff08;&#xff09;。 A信源 B信宿 C信道 D噪声 正确 正确答案&#xff1a;左边查询 学生答案…

oracle xe gentoo,Oracle在gentoo下安装

补充:解决ORACLE10G安装界面中文乱码问题&#xff0c;修改以下变量使安装界面为英文。export LC_CTYPEen_US.UTF-8以下为原文1.OS:Gentoo-linux-2.6.23-rc5Oracle:Oracle Database 10g Release 2 (10.2.0.1.0) for Linux x86下载地址&#xff1a;2.使用管理员账户建立Oracle用户…

【渝粤教育】电大中专跨境电子商务理论与实务 (11)作业 题库

1.在按照交易主体类型中&#xff0c;&#xff08; &#xff09;面对的最终客户为企业或集团客户&#xff0c;提供企业、产品、服务等相关信息。 A.O2O跨境电商或平台 B.B2B跨境电商或平台 C.B2C跨境电商或平台 D.C2C跨境电商或平台 错误 正确答案&#xff1a;左边查询 学生答案…

【渝粤题库】陕西师范大学209041 金融工程学 作业(专升本)

《金融工程学》作业 一、选择题 1.证券投资收益最大化和风险最小化这两个目标&#xff08; &#xff09;. A.可以同时实现&#xff1b; B.是一致的&#xff1b; C.是相互冲突的&#xff1b; D.大多数情况下可以同时实现. 2.金融工程中&#xff0c;通常用&#xff08; &#xff…

php 排序不影响索引,为什么不能通过索引避免排序操作呢??

谢谢各位的回复,尤其是棉花糖ONE!忘了说了,我的数据库版本是:10.2.0.4 的刚才做了一个10053事件.CASE WHEN STOCK_NUM>0 THEN 1 ELSE 0 END1 确实被重写成了STOCK_NUM>0.在这种情况下:SELECT * FROM(select /* INDEX(zsj_test) */pricefrom zsj_testwhere productnamerpa…

redis简单队列java_使用Redis的简单消息队列

redis简单队列java在本文中&#xff0c;我们将使用列表命令将Redis用作简单的消息队列。 假设我们有一个允许用户上传照片的应用程序。 然后在应用程序中&#xff0c;我们以不同大小显示照片&#xff0c;例如Thumb&#xff0c;Medium和Large。 在第一个实现中&#xff0c;我们…

【渝粤题库】陕西师范大学700002 细胞生物学

《细胞生物学》作业 一、名词解释 &#xff11;&#xff0e;细胞学说   &#xff12;&#xff0e;原位杂交    &#xff13;&#xff0e;细胞通讯   4&#xff0e;核纤层 5&#xff0e;早熟染色体凝集 6&#xff0e;细胞识别    7&#xff0e;细胞分化    &#xff18;…