Stream初步应用
一、什么是stream
Stream(流)是一个来自数据源的元素队列并支持聚合操作,数据来源可以从inputstream,数组,集合中获取;聚合操作可以类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。
二、stream基本方法的使用
public class StreamRefer {
public List<String> names = new ArrayList<>();
/**
* 流获取方式
*/
@Test
public void testGetStream(){
//流的获取
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
//方式一:通过集合的stream方法获取
Stream stream1 = names.stream();
System.out.println(stream1);
//方式二:通过stream的of方法获取
Stream stream2 = Stream.of(names);
System.out.println(stream2);
//方式三:通过parallelStream来创建并行流
Stream stream = names.parallelStream();
System.out.println(stream);
}
/**
* 流的方法测试
*/
@Test
public void testStreamMethodForeach(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//void forEach(Consumer action)对流进行循环操作,输入一个参数,无参数输出,无法流式编程
nameStream.forEach(s-> System.out.println(s.toUpperCase()));
}
@Test
public void testStreamMethodFilter(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//filter(Predicate p) 返回一个与给定判断条件匹配的元素组成的流,接受一个输入参数,返回一个booleal值,可以流式编程
nameStream.filter(s->s.length()>4).forEach(System.out::println);
}
@Test
public void testStreamMethodCount(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//count() 返回一个参数流的个数
System.out.println(nameStream.count());
}
@Test
public void testStreamMethodLimit(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
/*
* Stream limit(long maxSize) 获得流中前 maxSize 个元素,将元素添加到另一个流中返回
*如果 maxSize 大于等于当前流的元素个数,则所有元素都会获取到
*如果 maxSize 等于 0,则会获得一个空流。
*可以流式编程
*/
//1.获取前面几个流,当为0是为空流但不会为null
Stream<String> limitStream = nameStream.limit(0);
System.out.println(limitStream);
limitStream.forEach(System.out::println);
//2.获取前面几个流,当为大于size返回整个流
Stream<String> limitStreamWhole = nameStream.limit(5);
limitStreamWhole.forEach(System.out::println);
//3.获取前面几个流,当为小于于size大于0返回整个流
Stream<String> limitStreamPart = nameStream.limit(2);
limitStreamPart.forEach(System.out::println);
}
@Test
public void testStreamMethodSkip(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//跳过前面几个,可以流式编程
nameStream.skip(1).forEach(System.out::println);
}
@Test
public void testStreamMethodMap(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
List<String> values = new ArrayList<>();
values.add("张三");
values.add("李四");
Stream<String> nameStream = names.stream();
Stream<String> valueStream = values.stream();
// Stream concat(Stream a,Stream b)两个流合并返回一个新的流
Stream.concat(nameStream,valueStream).forEach(System.out::println);
}
@Test
public void testStreamMethodConcat(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//map(Function mapper) 该接口需要一个 Function 函数式接口参数,可以将当前流中的 T 类型数据转换为另一种 R 类型的流。
nameStream.map(name -> name.length()).forEach(System.out::println);
}
@Test
public void testStreamMethodSort(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
Stream<String> nameStream = names.stream();
//sorted(Comparator<? super T> comparator)排序
nameStream.map(name -> name.length()).sorted().forEach(System.out::println);
}
@Test
public void testStreamMethodCollect(){
names.add("zhangsan");
names.add("lisi");
names.add("wangwu");
//collect(toList())将流转成集合
List<Integer> convertCoinTypes = names.stream().map(coinType -> coinType.length()).collect(toList());
convertCoinTypes.forEach(System.out::println);
}
}
三、stream总结
注意点:①在流式编程中一样需要符合lambda表达式对域的规范;
②流式编程可以简化我们的编码风格。
Stream初步应用的更多相关文章
- Stream初步认识(一)
Stream初步认识(一)测试 简介 Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对 集合进行的操作,可以执行非常复杂的查找.过滤和映射数据等操作. 使用Stream AP ...
- Java8 stream学习
Java8初体验(二)Stream语法详解 Java 8 flatMap示例 第一个Stream Demo IDEA里面写Stream有个坑 虽然java文件中没错,但是但编译的时候还是报错了, In ...
- ASP.Net MVC开发基础学习笔记:五、区域、模板页与WebAPI初步
一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...
- ASP.Net MVC开发基础学习笔记(5):区域、模板页与WebAPI初步
一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...
- 分布式消息系统Kafka初步
终于可以写kafka的文章了,Mina的相关文章我已经做了索引,在我的博客中置顶了,大家可以方便的找到.从这一篇开始分布式消息系统的入门. 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到 ...
- CMake初步(2)
转自:<你所不知的OSG>第一章:CMake初步(2) http://bbs.osgchina.org/forum.php?mod=viewthread&tid=1229& ...
- 初步探究java中程序退出、GC垃圾回收时,socket tcp连接的行为
初步探究java中程序退出.GC垃圾回收时,socket tcp连接的行为 今天在项目开发中需要用到socket tcp连接相关(作为tcp客户端),在思考中发觉需要理清socket主动.被动关闭时发 ...
- C++面向对象程序设计之C++的初步知识
本节内容为学习谭浩强老师编写的<C++面向对象程序设计>的第1章 C++的初步知识 后的个人总结. 在正文开始之前,首先声明,我是Python程序员. 1.2.最简单的C++程序 例1 ...
- centos中pipelinedb安装及初步使用
安装 下载安装包 https://www.pipelinedb.com/download 创建系统文件目录和日志目录 pipelinedb安装 使用非root用户,初始化pipelinedb 修改配置 ...
随机推荐
- python-django-01
1.Python工具 - pip 1.作用 Python的软件包管理器,有一些python包被集成到了pip中.只要被集成到pip中的包,都允许通过pip直接安装 2.安装 pip sudo apt ...
- 【EMV L2】Cardholder Verification Rule(CVR) Format
Cardholder Verification Rule(CVR)由两个字节组成: 高字节为Cardholder Verification Method (CVM) Codes,表示执行Cardhol ...
- Python中的变量作用域
python中变量作用域包括: L (Local) 局部作用域,函数内部声明但没有使用global的变量E (Enclosing) 闭包函数外的函数中,def或者lambda的本地作用域G (Glob ...
- python 三种 安装包的方法
1.pycharm安装第三方库 然后点+搜索库安装. 注意 : 有时候点+会出现下图提示:Nothing to show,这就需要在点加号前点一下绿色圈圈的conda标志. 点+号出现下图的内容才是正 ...
- GitHub 优秀的项目地址
Type LibDescription LibLocation Android SlidingMenu https://github.com/jfeinstein10/SlidingMenu ...
- 在Windows下通过压缩包方式安装MySQL
需求:下载MySQL有两种方法,一是下载可执行文件,通过点点点的方式,比较简单没什么技术含量,但是之前通过此方法下载的MySQL与Python进行连接交互的时候总是报1045错误,一直没找到原因,尝试 ...
- Leetcode 两数之和 (散列表)
给定一个整数数组和一个目标值,找出数组中和为目标值的两个数. 你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用. 示例: 给定 nums = [2, 7, 11, 15], target ...
- php 服务端允许跨域访问
加上需要允许跨域访问,配置如下(一下配置内容前不允许有其他任何输出操作): //设置允许跨域的 请求源地址//方式一:header("Access-Control-Allow-Origin: ...
- 理解java容器:iterator与collection,容器的起源
关于容器 iterator与collection:容器的起源 iterator的简要介绍 iterable<T> iterator<T> 关于remove方法 Collecti ...
- java 注解 知识整理
一.前言 注解(也称为元数据)为我们在代码中添加信息提供了一种方法,它在 一定程度上将元数据与源代码文件结合在一起.它是从java 5 开始引入的.通过使用注解,我们可以将元数据保存在Java源代码之 ...