Stream聚合函数
Stream班介绍
幼稚园开学的第一天,各们家长把小朋友送到了园里,各位小朋友都你看看我,我看看你。有的嚎啕大哭,有的呆若木鸡....这里时候园长安排我拿来小本本记录入园的小朋友....
记录小朋友
身为程序员的我当然不会拿笔来记录了。我准备代码来记录下、先写小孩子的类Child
在映射基本信息
@Getter
@Setter
@NoArgsConstructor
public class Child {
private int age; //年龄
private String firstName; //名
private String lastName; //姓
private String fullName; //全名
Child(int age, String lastName, String firstName) {
this.age = age;
this.lastName = lastName;
this.firstName = firstName;
this.fullName = lastName + firstName;
}
}
在创建一个班名册类ClassBook
来记录Stream班的入园所有学生!
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
public class ClassBook {
private String name = "Stream班名册"; //班名册记录
private List<Child> kids = new LinkedList<>();//名册表
}
由于YQ的原因,我们园小班只收了10个小朋友,现在的小朋友可了不得,光这名儿起的就有文化,我先把这些小朋友记录下来再说!
public class StreamMathApiTest {
private ClassBook book;
@Before
public void __setUp() {
List<Child> allChild = new LinkedList<>();
allChild.add(new Child(3.0F, "萧", "峰"));
allChild.add(new Child(3.1F, "任", "我行"));
allChild.add(new Child(3.2F, "郭", "靖"));
allChild.add(new Child(3.5F, "洪", "七公"));
allChild.add(new Child(3.6F, "黄", "药师"));
allChild.add(new Child(3.9F, "欧", "阳峰"));
allChild.add(new Child(3.4F, "任", "飞燕"));
allChild.add(new Child(3.7F, "杨", "过"));
allChild.add(new Child(3.3F, "杨", "逍"));
allChild.add(new Child(3.8F, "石", "破天"));
this.book = new ClassBook("Stream班名册", allChild);
}
}
还是写程序快啊,不用做Excel表格,一个一个输入。
计算总学生(Count)
刚把这些小学生记录完,还没歇着,园长就让我们汇报下今天一共入园了多少学生~,等待哈,我先跑个代码看一看!
@Test
public void test_count() {
//count 函数
long count = this.book.getKids().stream().
count();
Assert.assertTrue(count == 10l);
}
这不,能让电脑动的我决不动脑子。一个就算出个10
来。我赶紧向园长汇报!园长跨我算的快!刚准备喝口水、园让又让我计算下我们班平均年龄!!!没办法,我再写个程序!
计算平均年龄(mapTo(xxx) + Avgage)
@Test
public void test_avg() {
double avgAge = this.book.getKids().
stream().
mapToDouble(Child::getAge).
average().orElse(0l);
Assert.assertEquals("Error calc!", "3.45", Double.toString(avgAge));
}
程序真是个好东西,你看不用一个一个输入,我写好代码,它自动跑出结果就行!帮我算出了平均数为3.45,这不,园长真的再次跨我能干!笑着说:顺便给我算下咱们班最大的年龄是多少!、我一脸无耐。
计算最大/小值(Max/Min)
@Test
public void test_max() {
//最大值
Child maxChild = this.book.getKids().stream().
max((o1, o2) -> {
//借助BigDecimal函数来比较,也可以把Float转成int来进行比较,方法很多种。
BigDecimal first = new BigDecimal(String.valueOf(o1.getAge()));
BigDecimal second = new BigDecimal(String.valueOf(o2.getAge()));
return first.compareTo(second);
}).get();
Assert.assertEquals("欧阳峰", maxChild.getFullName());
//最小值 返回过来即可
Child minChild = this.book.getKids().stream().
max((o1, o2) -> {
BigDecimal first = new BigDecimal(String.valueOf(o1.getAge()));
BigDecimal second = new BigDecimal(String.valueOf(o2.getAge()));
return second.compareTo(first);
}).get();
Assert.assertEquals("萧峰", minChild.getFullName());
}
反正不用我一个一个计算,我就做个顺水人情,顺便把咱们班最小的朋友也给您找出来!省的你还让我回来算!这不,最大的是
欧阳峰/3岁9个月,最小是的萧峰/3岁挂0、心想这下都给你整明白了吧!应该不用算啥了吧!这不刚想完,就让我回来再算下总年龄!
我...好人做到底,送佛送到西!我就再写一手!
累加(reduce)
@Test
public void test_reduce() {
Float totalAge = this.book.getKids().stream().
map(Child::getAge)
.reduce(0f, Float::sum);
//Double::sum/Interge::sum/......
Assert.assertEquals(totalAge.toString(), "34.5");
}
算出来了!这加减乘除平均数最大最小都给你整出来了,这下没有啥要计算了的吧!
好了、今天的Stream
教程到此结束!下次待园长吩咐了才做!
代码在GitHub
Stream聚合函数的更多相关文章
- Spark SQL 用户自定义函数UDF、用户自定义聚合函数UDAF 教程(Java踩坑教学版)
在Spark中,也支持Hive中的自定义函数.自定义函数大致可以分为三种: UDF(User-Defined-Function),即最基本的自定义函数,类似to_char,to_date等 UDAF( ...
- 可以这样去理解group by和聚合函数
写在前面的话:用了好久group by,今天早上一觉醒来,突然感觉group by好陌生,总有个筋别不过来,为什么不能够select * from Table group by id,为什么一定不能是 ...
- TSQL 聚合函数忽略NULL值
max,min,sum,avg聚合函数会忽略null值,但不代表聚合函数不返回null值,如果表为空表,或聚合列都是null,则返回null.count 聚合函数忽略null值,如果聚合列都是null ...
- SQL Server 聚合函数算法优化技巧
Sql server聚合函数在实际工作中应对各种需求使用的还是很广泛的,对于聚合函数的优化自然也就成为了一个重点,一个程序优化的好不好直接决定了这个程序的声明周期.Sql server聚合函数对一组值 ...
- Mongodb学习笔记四(Mongodb聚合函数)
第四章 Mongodb聚合函数 插入 测试数据 ;j<;j++){ for(var i=1;i<3;i++){ var person={ Name:"jack"+i, ...
- sql语句 之聚合函数
聚合分析 在访问数据库时,经常需要对表中的某列数据进行统计分析,如求其最大值.最小值.平均值等.所有这些针对表中一列或者多列数据的分析就称为聚合分析. 在SQL中,可以使用聚合函数快速实现数据的聚 ...
- oracle数据库函数之============‘’分析函数和聚合函数‘’
1分析函数 分析函数根据一组行来进行聚合计算,用于计算完成狙击的累积排名等,分析函数为每组记录返回多个行 rank_number() 查询结果按照次序排列,不存在并列和站位的情况,可以用于做Oracl ...
- ORACLE 自定义聚合函数
用户可以自定义聚合函数 ODCIAggregate,定义了四个聚集函数:初始化.迭代.合并和终止. Initialization is accomplished by the ODCIAggrega ...
- sql 聚合函数、排序方法详解
聚合函数 count,max,min,avg,sum... select count (*) from T_Employee select Max(FSalary) from T_Employee 排 ...
随机推荐
- 【C#】 Stopwatch详解
Stopwatch的命名空间是using System.Diagnostics; 1 namespace System.Diagnostics 2 { 3 // 4 // 摘要: 5 // 提供一组方 ...
- mysql复制内容到一张新表
-- 1.复制表结构及数据到新表 CREATE TABLE 新表 SELECT * FROM 旧表 -- 2.只复制表结构到新表 CREATE TABLE 新表 SELECT * FROM 旧表 WH ...
- springboot @value无法赋值
1解决方式在类上在加@Compent @Component@EnableBinding(Sink.class)public class ReceiveMessageListenerController ...
- nacos在nginx下集群以及数据库问题
持久化mysql时指定数据库编辑application.properties spring.datasource.platform=mysql db.num=1 db.url.0=jdbc:mysql ...
- linux上传下载文件(转载https://www.jb51.net/article/143112.htm)
转载于:https://www.jb51.net/article/143112.htmLinux下目录复制:本机->远程服务器 1 scp -r /home/shaoxiaohu/test1 z ...
- canvas——绘制解锁图案
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 常用cron表达式
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点 0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时 0 0 12 ? * WED 表示每个星期三中午12点 " ...
- openresty lua_ssl_trusted_certificate 问题
lua_ssl_trusted_certificate 语法: lua_ssl_trusted_certificate 默认: no 环境: http, server, location 指定一个 P ...
- Tensorflow之TFRecord的原理和使用心得
本文首发于微信公众号「对白的算法屋」 大家好,我是对白. 目前,越来越多的互联网公司内部都有自己的一套框架去训练模型,而模型训练时需要的数据则都保存在分布式文件系统(HDFS)上.Hive作为构建在H ...
- VS dll 引用依赖
在公司实习过程中,经常遇到三个问题: 开发环境 dll引用依赖 dll版本控制 一般公司都会配置开发/测试/Lab/线上四个环境,之后不管时开发什么项目,都与环境分不开边.这个和dll版本控制暂且记下 ...