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聚合函数的更多相关文章

  1. Spark SQL 用户自定义函数UDF、用户自定义聚合函数UDAF 教程(Java踩坑教学版)

    在Spark中,也支持Hive中的自定义函数.自定义函数大致可以分为三种: UDF(User-Defined-Function),即最基本的自定义函数,类似to_char,to_date等 UDAF( ...

  2. 可以这样去理解group by和聚合函数

    写在前面的话:用了好久group by,今天早上一觉醒来,突然感觉group by好陌生,总有个筋别不过来,为什么不能够select * from Table group by id,为什么一定不能是 ...

  3. TSQL 聚合函数忽略NULL值

    max,min,sum,avg聚合函数会忽略null值,但不代表聚合函数不返回null值,如果表为空表,或聚合列都是null,则返回null.count 聚合函数忽略null值,如果聚合列都是null ...

  4. SQL Server 聚合函数算法优化技巧

    Sql server聚合函数在实际工作中应对各种需求使用的还是很广泛的,对于聚合函数的优化自然也就成为了一个重点,一个程序优化的好不好直接决定了这个程序的声明周期.Sql server聚合函数对一组值 ...

  5. Mongodb学习笔记四(Mongodb聚合函数)

    第四章 Mongodb聚合函数 插入 测试数据 ;j<;j++){ for(var i=1;i<3;i++){ var person={ Name:"jack"+i, ...

  6. sql语句 之聚合函数

      聚合分析 在访问数据库时,经常需要对表中的某列数据进行统计分析,如求其最大值.最小值.平均值等.所有这些针对表中一列或者多列数据的分析就称为聚合分析. 在SQL中,可以使用聚合函数快速实现数据的聚 ...

  7. oracle数据库函数之============‘’分析函数和聚合函数‘’

    1分析函数 分析函数根据一组行来进行聚合计算,用于计算完成狙击的累积排名等,分析函数为每组记录返回多个行 rank_number() 查询结果按照次序排列,不存在并列和站位的情况,可以用于做Oracl ...

  8. ORACLE 自定义聚合函数

    用户可以自定义聚合函数  ODCIAggregate,定义了四个聚集函数:初始化.迭代.合并和终止. Initialization is accomplished by the ODCIAggrega ...

  9. sql 聚合函数、排序方法详解

    聚合函数 count,max,min,avg,sum... select count (*) from T_Employee select Max(FSalary) from T_Employee 排 ...

随机推荐

  1. Linux虚拟机系统中进行redis的哨兵模式配置

    一.配置步骤 开一台虚拟机1.创建三个redis配置文件:/etc/redis下pidfile "/var/run/redis6380.pid" redis的id号port 638 ...

  2. mybatis传入参数为0被误认为是空字符串的解决方法

    在mbatis中使用Xml配置sql语句时,出现了这样一个问题.当我传入的参数为0去做判断时,mybatis会把参数0当成是空字符串去判断而引起查询结果错误 所以在做项目时一定要注意,用到MyBati ...

  3. mzy git学习,git推送到远程库(八)

    git在同步到远程库 关于git中多个用户切换的事情: 完全使用账户密码策略连接远程库: 之前一直尝试在本地切换多个用户,发现一直不行,很奇怪?后面发现必须要去win10的凭据管理器删除当前git的凭 ...

  4. struts2思想学习(一)

    OOP 面向对象编程 AOP 面向切面编程 而在struts2 处处体现了面向切面编程的思想(动态代理最典型)! 拦截器其实也是面向切面编程!拦截器切断了所有请求到action的操作 并做了很多的前提 ...

  5. mybatis根据表逆向自动化生成代码(自动生成实体类、mapper文件、mapper.xml文件)

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  6. twemproxy《一》

    twemproxy 做redis客户端中间代理的时候,如果redis有密码时,需要在nutcracker.yml中添加密码:

  7. Redis(二):基本数据类型

    基础 # redis默认有16个数据库,数组下标从0开始,默认使用0号库 # 当我们启动服务器并连接客户端之后: set <key> <value> # 向数据库中添加数据用于 ...

  8. indexedDB数据库创建

    1.首先需要使用使用indexedDB.open()方法,打开数据库 2.通过createObjectStore方法创建表, 创建表之后, 这个表通过createIndex方法创建索引 3.通过tra ...

  9. Dubbo | Dubbo快速上手笔记 - 环境与配置

    目录 前言 1. Dubbo相关概念 1.1 自动服务发现工作原理 2. 启动文件 2.1 zookeeper-3.4.11\bin\zkServer.cmd 2.2 zookeeper-3.4.11 ...

  10. Java线程池工作原理

    前言 当项目中有频繁创建线程的场景时,往往会用到线程池来提高效率.所以,线程池在项目开发过程中的出场率是很高的. 那线程池是怎么工作的呢?它什么时候创建线程对象,如何保证线程安全... 什么时候创建线 ...