一、什么是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初步应用的更多相关文章

  1. Stream初步认识(一)

    Stream初步认识(一)测试 简介 Stream 是 Java8 中处理集合的关键抽象概念,它可以指定你希望对 集合进行的操作,可以执行非常复杂的查找.过滤和映射数据等操作. 使用Stream AP ...

  2. Java8 stream学习

    Java8初体验(二)Stream语法详解 Java 8 flatMap示例 第一个Stream Demo IDEA里面写Stream有个坑 虽然java文件中没错,但是但编译的时候还是报错了, In ...

  3. ASP.Net MVC开发基础学习笔记:五、区域、模板页与WebAPI初步

    一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...

  4. ASP.Net MVC开发基础学习笔记(5):区域、模板页与WebAPI初步

    一.区域—麻雀虽小,五脏俱全的迷你MVC项目 1.1 Area的兴起 为了方便大规模网站中的管理大量文件,在ASP.NET MVC 2.0版本中引入了一个新概念—区域(Area). 在项目上右击创建新 ...

  5. 分布式消息系统Kafka初步

    终于可以写kafka的文章了,Mina的相关文章我已经做了索引,在我的博客中置顶了,大家可以方便的找到.从这一篇开始分布式消息系统的入门. 在我们大量使用分布式数据库.分布式计算集群的时候,是否会遇到 ...

  6. CMake初步(2)

    转自:<你所不知的OSG>第一章:CMake初步(2) http://bbs.osgchina.org/forum.php?mod=viewthread&tid=1229& ...

  7. 初步探究java中程序退出、GC垃圾回收时,socket tcp连接的行为

    初步探究java中程序退出.GC垃圾回收时,socket tcp连接的行为 今天在项目开发中需要用到socket tcp连接相关(作为tcp客户端),在思考中发觉需要理清socket主动.被动关闭时发 ...

  8. C++面向对象程序设计之C++的初步知识

    本节内容为学习谭浩强老师编写的<C++面向对象程序设计>的第1章  C++的初步知识  后的个人总结. 在正文开始之前,首先声明,我是Python程序员. 1.2.最简单的C++程序 例1 ...

  9. centos中pipelinedb安装及初步使用

    安装 下载安装包 https://www.pipelinedb.com/download 创建系统文件目录和日志目录 pipelinedb安装 使用非root用户,初始化pipelinedb 修改配置 ...

随机推荐

  1. github 和 jupyter

    放在github上的.ipynb文件可以用jupyter nbviewer来查看和分享. nbviewer首页: http://nbviewer.jupyter.org/ 输入github的名字或网址 ...

  2. 一种hyperscan API使用(1)

    hyperscan: 编译和安装:http://www.cnblogs.com/zzqcn/p/4900643.html 简单介绍:http://www.cnblogs.com/zzqcn/p/489 ...

  3. 开发Canvas 绘画应用(三):实现对照绘画

    需求分析 在我的毕设中,提出了视图引导的概念,由两部分功能组成: (1)可以对照着图片进行绘画,即将图片以半透明的方式呈现在绘图板上,然后用户可以对照着进行绘画: (2)可以直接将简笔画图片直接拖拽到 ...

  4. Python全栈之路----常用模块----subprocess模块

    我们经常需要通过Python去执行一条系统命令或脚本,系统的shell命令是独立于你的python进程之外的,每执行一条命令,就是发起一个新进程,通过python调用系统命令或脚本的模块在python ...

  5. 通过sql查找指定字段存在哪些表中

    select * from INFORMATION_SCHEMA.columns where COLUMN_NAME Like '%order_type%';

  6. C# 代码补全

    cw + Tab + Tab           输出 Console.WriteLine(); try +Tab+Tab           输出 try catch代码块 foreach + Ta ...

  7. 关于JavaScript的框架和库

    0----无所不能的JavaScript: 说到javascript,最先想到的是用于网页交互的脚本语言,这是最早netscope公司开发的基于浏览器内核的语言:但是最近几年一位大牛一chorme内核 ...

  8. python中的time模块和datetime模块

    >>> import time>>> time.time()1511330865.656656>>> time.localtime(time.ti ...

  9. centos 终端字体错位个别字母中间有间隔的解决

    问题描述: linux系统:centos 终端:图形界面终端,通过startx启动 现象:通过终端输入的字体有重叠,字母之间的间隔也很大.由于字体安装不正确导致. 解决方法:通过下面字体的安装命令可以 ...

  10. 实体lis<T>t转换datatable

    public static DataTable ListToTable<T>(List<T> list) {             Type type = typeof(T) ...