Java8新特性steam流

一、包装数据类型

@Test
public void main22() {
List<Integer> list = new ArrayList<Integer>(){{
add(7); add(5); add(1); add(2);
add(8); add(4); add(3); add(6);
add(3); add(6); add(3); add(6);
}};
// 过滤
List<Integer> filterList = list.stream().filter(a -> a < 5).collect(Collectors.toList());
// 排序(正序)
List<Integer> sortList1 = list.stream().sorted().collect(Collectors.toList());
List<Integer> sortList2 = list.stream().sorted(Comparator.comparing(a -> a, Comparator.naturalOrder())).collect(Collectors.toList());
// 排序(倒序)
List<Integer> sortList3 = list.stream().sorted(Comparator.comparing(a -> a, Comparator.reverseOrder())).collect(Collectors.toList());
// 最大数
Integer max = list.stream().max(Comparator.comparing(a -> a, Comparator.naturalOrder())).get();
// 最小数
Integer min = list.stream().min(Comparator.comparing(a -> a, Comparator.naturalOrder())).get();
// 去重
List<Integer> distinctList = list.stream().distinct().collect(Collectors.toList());
// 对每个元素进行操作
List<Integer> mapList = list.stream().map(a -> a * a).collect(Collectors.toList()); System.out.println(max);
System.out.println(min);
mapList.forEach(a -> System.out.print(a+" "));
}

二、Map类型

import org.apache.commons.lang.StringUtils;

@Test
public void test() {
HashMap<String, Integer> map = new HashMap<String, Integer>(){{
put("A", 1); put("B", 2); put("C", 3); put("D", 4);
put("E", 1); put("F", 1); put("", 1); put("", 1);
}};
// key集合转list
List<String> keyList1 = map.keySet().stream().filter(a -> StringUtils.isNotBlank(a)).collect(Collectors.toList());
List<String> keyList2 = map.entrySet().stream().map(entry -> entry.getKey()).filter(a -> StringUtils.isNotBlank(a)).collect(Collectors.toList());
// value集合转list
List<Integer> valueList = map.entrySet().stream().map(entry -> entry.getValue()).collect(Collectors.toList());
// 处理value,同理可处理key
Map<String, Integer> newMap = map.entrySet().stream().collect(Collectors.toMap(Map.Entry::getKey, a -> a.getValue() * a.getValue()));
// key value换位,key冲突时,新value替换旧value
Map<Integer, String> reMap1 = map.entrySet().stream().collect(Collectors.toMap(Map.Entry::getValue,
Map.Entry::getKey,
(String val1, String val2) -> val2
));
// key value换位,key冲突时,加入value列表中
Map<Integer, List<String>> reMap2 = map.entrySet().stream().collect(Collectors.toMap(Map.Entry::getValue,
a -> new ArrayList<String>(){{ add(a.getKey()); }},
(List<String> v1, List<String> v2) -> {
v1.addAll(v2);
return v1;
}
)); keyList2.forEach(a -> System.out.printf(a + " "));
System.out.println();
reMap2.entrySet().forEach(entry -> System.out.println("key: " + entry.getKey() + ", val: " + entry.getValue()));
}

三、对象List

@Test
public void test() {
List<User> list = new ArrayList<User>() {{
add(new User(1, "半月", 18));
add(new User(2, "无霜", 22));
add(new User(3, "半月无霜", 24));
add(new User(3, "半霜", 28));
add(new User(4, "半霜", 28));
}};
// 转Map<id, user>,如遇到key冲突,可参考第二段map解决办法
Map<Integer, User> map1 = list.stream().collect(Collectors.toMap(User::getId, Function.identity()));
Map<Integer, User> map2 = list.stream().collect(Collectors.toMap(User::getId, a -> a));
// 查找
User user = list.stream().filter(a -> "半月".equals(a.getName())).findFirst().get();
// 过滤计数
long count = list.stream().filter(a -> a.getAge() >= 22).count();
// 排序(通过年龄排正序)
List<User> orderList = list.stream().sorted(Comparator.comparing(User::getAge, Comparator.naturalOrder())).collect(Collectors.toList());
// 排序(通过年龄排倒序)
List<User> reorderList = list.stream().sorted(Comparator.comparing(User::getAge, Comparator.reverseOrder())).collect(Collectors.toList());
// 对象去重(通过ID去重)
List<User> unionUser = list.stream().collect(
Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getId()))), ArrayList::new));
// 属性集合(此处为名字集合)
List<String> nameList = list.stream().map(User::getName).collect(Collectors.toList());
// 截取,skip:跳过前n个,limit:取n个
List<User> limitList = list.stream().skip(1).limit(2).collect(Collectors.toList());
// 判断是否存在(半月是否存在)
boolean isHave1 = list.stream().anyMatch(a -> "半月".equals(a.getName()));
// 判断所有是否满足(是否都大于16岁)
boolean fullAge = list.stream().allMatch(a -> a.getAge() > 16);
// 判断是否不存在(里面没有ID为10的用户)
boolean isHave2 = list.stream().noneMatch(a -> "10".equals(a.getId())); limitList.forEach(System.out::println);
System.out.println(isHave2? "没有ID为10的用户": "有ID为10的用户");
} @Data
@AllArgsConstructor
class User{
private Integer id;
private String name;
private Integer age;
}

功能:Java8新特性steam流的更多相关文章

  1. Java8 新特性之流式数据处理

    一. 流式处理简介 在我接触到java8流式处理的时候,我的第一感觉是流式处理让集合操作变得简洁了许多,通常我们需要多行代码才能完成的操作,借助于流式处理可以在一行中实现.比如我们希望对一个包含整数的 ...

  2. Java8 新特性之流式数据处理(转)

    转自:https://www.cnblogs.com/shenlanzhizun/p/6027042.html 一. 流式处理简介 在我接触到java8流式处理的时候,我的第一感觉是流式处理让集合操作 ...

  3. 这可能是史上最好的 Java8 新特性 Stream 流教程

    本文翻译自 https://winterbe.com/posts/2014/07/31/java8-stream-tutorial-examples/ 作者: @Winterbe 欢迎关注个人微信公众 ...

  4. Java8新特性 Stream流式思想(二)

    如何获取Stream流刚开始写博客,有一些不到位的地方,还请各位论坛大佬见谅,谢谢! package cn.com.zq.demo01.Stream.test01.Stream; import org ...

  5. Java8 新特性 Steam() 中间有状态操作

    中间有状态操作 Java8 新特性 Stream 练习实例   中间操作,就是把数据处理成自己想要的类型,并且有状态操作,是在所有的数据基础上进行操作的.比如dictinct(去重),sorted(排 ...

  6. Java8新特性Stream流应用示例

    Java8新特性介绍 过滤集合 List<String> newList = list.stream().filter(item -> item != null).collect(C ...

  7. java8新特性——并行流与顺序流

    在我们开发过程中,我们都知道想要提高程序效率,我们可以启用多线程去并行处理,而java8中对数据处理也提供了它得并行方法,今天就来简单学习一下java8中得并行流与顺序流. 并行流就是把一个内容分成多 ...

  8. Java8 新特性 —— Stream 流式编程

    本文部分摘自 On Java 8 流概述 集合优化了对象的存储,大多数情况下,我们将对象存储在集合是为了处理他们.使用流可以帮助我们处理对象,无需迭代集合中的元素,即可直接提取和操作元素,并添加了很多 ...

  9. java8 新特性Stream流的应用

    作为一个合格的程序员,如何让代码更简洁明了,提升编码速度尼. 今天跟着我一起来学习下java 8  stream 流的应用吧. 废话不多说,直入正题. 考虑以下业务场景,有四个人员信息,我们需要根据性 ...

随机推荐

  1. sqlyog如何增删改查?

    转: sqlyog如何增删改查? 下面是一道完整的 sqlyog 增删改查的练习, 顺着做下去,可以迅速掌握. 1. 创建部门表dept,并插入数据: 2. 创建emp员工表,并插入数据: sql 代 ...

  2. 微信小程序点击按钮将图片保存到手机

    SaveCard: function(e) { let that = this; console.log('保存'); var imgSrc = e.currentTarget.dataset.img ...

  3. CCF(引水入城:60分):最大流+ISAP算法

    引水入城 201703-5 这从题目分析来看很像最大流的问题,只需要增加一个超级源点和一个超级汇点就可以按照题意连边再跑最大流算法. 因为数据量太大了,肯定会超时.但是没有想到可行的解决方法. #in ...

  4. CCF(公共钥匙盒):思维+模拟

    公共钥匙盒 201709-2 这题的思路一开始不是很清晰,一开始想用贪心去做.但是发现按照题目的思路不对.所以这里采用的是类似于多项式的加减的处理. #include<iostream> ...

  5. 在scanf函数中占位符使用错误而产生的一些错误

    出现的问题 在做编程题的的时候,遇到了一个很奇怪的错误,出问题的代码如下: 1 #include <cstdio> 2 using namespace std; 3 4 int main( ...

  6. MarkFormat,一个在Word中使用Mark进行格式化的插件

    MarkFormat(标记格式化),是一款在Word中基于标记进行格式化的工具. 让我们看下具体效果. 首先是有标记的文本 点击格式化之后 点击去除标记之后(去除标记也会进行格式化) 如果想要恢复标记 ...

  7. 测试平台系列(4) 使用Flask蓝图(blueprint)

    使用Flask蓝图(blueprint) 回顾 先来看一下上一篇的作业吧,使用「logbook」的时候,遇到了时区不对的情况.那么我们怎么去解决这个问题呢? 实际上logbook默认采用的是世界标准时 ...

  8. (十三)数据库查询处理之QueryExecution(2)

    (十三)数据库查询处理之QueryExecution(2) 实验室这一周真的忙爆(虽然都是各种打杂的活)所以拖了很久终于在周末(摸鱼)把实验3做完了.同时准备把和查询这一块有关的博客补一下.然后就进入 ...

  9. Netty源码 reactor 模型

    翻阅源码时,我们会发现netty中很多方法的调用都是通过线程池的方式进行异步的调用, 这种  eventLoop.execute 方式的调用,实际上便是reactor线程.对应项目中使用广泛的NioE ...

  10. Mardown语法

    1.什么是Markdown Mardown是一种文本标记语言,使用它,能让我们更加专注于内容的输出,而不是排版样式. 我们平常使用的.txt文档书写的文字是没有样式的,使用Markdown语法就可以给 ...