流式编程

流的一个核心好处是,它使得程序更加短小并且更易理解。

public class Demo1 {
public static void main(String[] args) {
new Random(47)
// ints() 方法产生一个流并且 ints() 方法有多种方式的重载
// — 两个参数限定了数值产生的边界。这将生成一个整数流
.ints(5,60)
.distinct()//distinct() 来获取它们的非重复值
.limit(7)//使用 limit() 方法获取前 7 个元素
.sorted()//使用 sorted() 方法排序
// forEach() 方法遍历输出,它根据传递给它的函数对每个
// 流对象执行操作。
.forEach(System.out::println);
// 我们传递了一个可以在控制台显示每个元素的方法引用。System.out::println
}
}

流操作的类型有三种:创建流,修改流元素(中间操作, Intermediate Operations),消费流元素(终端操作, Terminal Operations)。

创建流
public class BuildUp {
public static void main(String[] args) {
Stream.of("aaa","bbb","vvv").forEach(System.out::print);
Stream.of(1111,2222,3333).forEach(System.out::print); //从 Map 集合中产生流数据,。然后分别调用 getKey() 和 getValue() 获取值。
Map<String,Double> m = new HashMap<>();
m.put("AA",1.1);
m.put("BB",1.3);
m.put("DDD",3.1);
m.put("CCC",2.1); //我们首先调用 entrySet() 产生一个对象流,每个对象都包含一个 key 键以及与其相关联的 value 值
// 将对象作为e参数传到后面,
m.entrySet().stream().map(e -> e.getKey()+":"+
e.getValue()).forEach(System.out::println);
}
}

generate()

/*
Supplier 接口有一个方法就是get
*/
public class Generate implements Supplier<String>{
Random rand = new Random(47);
char[] letters = "ABCDEFGHIJK".toCharArray();
// 重写接口中的函数,返回String类型值
public String get(){
// 在指定的数组里面挑选字母
// Random.nextInt() 的参数代表可以接受的最大的随机数范围
return "" + letters[rand.nextInt(letters.length)];
} public static void main(String[] args) {
String word = Stream.generate(new Generate()).limit(20)
.collect(Collectors.joining());
System.out.println(word);
System.out.println("#######################");
Stream.generate(() -> "done").limit(3)
.forEach(System.out::println); }
}

Stream.iterate()

static <T> Stream<T> iterate(T seed, UnaryOperator<T> f)

返回有序无限连续 Stream由函数的迭代应用产生 f至初始元素 seed ,产生 Stream包括 seedf(seed)f(f(seed)) ,等 

以种子(第一个参数)开头,并将其传给方法(第二个参数)。方法的结果将添加到流,并存储作为第一个参数用于下次调用 iterate()

Stream<T> skip(long n)

在丢弃流的第一个 n元素后,返回由该流的 n元素组成的流。
public class Fibonacci {
int x =1;
// 匿名函数
Stream<Integer> numbers(){
// lambada表达式的函数
return Stream.iterate(0,i ->{
int result = x +i;
x = i;
return result;
});
} public static void main(String[] args) {
new Fibonacci().numbers()
.skip(10)
.limit(10)
.forEach(System.out::println);
} }
/*
斐波那契数列就是签两个数相加得到写一个元素
55
89
144
233
377
610
987
1597
2584
418
*/

流的建造者模式

static <T> Stream.Builder<T> builder()

返回一个 Stream的构建器。
public class FileTo {
// 建立构建器,builder
Stream.Builder<String> builder = Stream.builder();
public FileTo(String fp) throws Exception{
Files.lines(Paths.get(fp))
.skip(1)
//
.forEach(line ->{for (String w:line.split("[ .?,]+"))//以上面做分割
builder.add(w);//分割完的部分加入流构建器里面
});
}
Stream<String> stream(){
return builder.build();
} public static void main(String[] args) throws Exception {
// 实例化流对象
new FileTo("src/flow/FileTo.java")
.stream()
.limit(7)
.map(w -> w +" ")
.forEach(System.out::print);
}
}
/*
import java nio file Files; import
*/

注意,构造器会添加文件中的所有单词(除了第一行,它是包含文件路径信息的注释),但是其并没有调用 build()。只要你不调用 stream() 方法,就可以继续向 builder 对象中添加单词。

在该类的更完整形式中,你可以添加一个标志位用于查看 build() 是否被调用,并且可能的话增加一个可以添加更多单词的方法。在 Stream.Builder 调用 build() 方法后继续尝试添加单词会产生一个异常。

Arrays.stream()

Arrays 类中含有一个名为 stream() 的静态方法用于把数组转换成为流

public class Demo2 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("AAA");
list.add("BBB");
list.add("CCC");
list.add("DDD");
list.add("EEE");
System.out.println(list); list.stream().forEach(System.out::println);
}
}

stream() 同样可以产生 IntStream,LongStream 和 DoubleStream。

public class IntLongDouble {

    public static void main(String[] args) {
// int stream
Arrays.stream(new int[] {1,2,3,4,5})
.forEach(n -> System.out.format("%d ",n));//lamabad表达式
System.out.println();
System.out.println("#######################");
//指定从哪里开始到哪里结束,左闭右开区间
Arrays.stream(new double[] {1.1,2.2,3.3,4.4,5.5,6.6,7.7},3,6)
.forEach(n -> System.out.println(n));
System.out.println("##############"); Arrays.stream(new long[] {111111,444444,444999})
.forEach(System.out::println);//引用 }
}

中间操作跟踪和调试

java-流式编程的更多相关文章

  1. 20190827 On Java8 第十四章 流式编程

    第十四章 流式编程 流的一个核心好处是,它使得程序更加短小并且更易理解.当 Lambda 表达式和方法引用(method references)和流一起使用的时候会让人感觉自成一体.流使得 Java ...

  2. Stream流式编程

    Stream流式编程   Stream流 说到Stream便容易想到I/O Stream,而实际上,谁规定“流”就一定是“IO流”呢?在Java 8中,得益于Lambda所带来的函数式编程,引入了一个 ...

  3. JDK8新特性(二) 流式编程Stream

    流式编程是1.8中的新特性,基于常用的四种函数式接口以及Lambda表达式对集合类数据进行类似流水线一般的操作 流式编程分为大概三个步骤:获取流 → 操作流 → 返回操作结果 流的获取方式 这里先了解 ...

  4. Java反应式编程(1)

    您好,我是湘王,这是我的博客园,欢迎您来,欢迎您再来- 前面把Java函数式编程的由来和最主要的核心知识点讲完了.包括比较难懂的Lambda表达式是怎么演变而来的也全部都撸了一遍.Lambda表达式这 ...

  5. Java 链式编程

    这里来做一个Java 链式编程的例子,基本就是每次返回一个对象本身,这样就能够去调用对象的方法和属性. package com.sun; public class Demo05 { /** * @pa ...

  6. JAVA流式布局管理器--JAVA基础

    JAVA流式布局管理器的使用: FlowLayoutDeme.java: import java.awt.*;import javax.swing.*;public class FlowLayoutD ...

  7. golang的极简流式编程实现

    传统的过程编码方式带来的弊端是显而易见,我们经常有这样的经验,一段时间不维护的代码或者别人的代码,突然拉回来看需要花费较长的时间,理解原来的思路,如果此时有个文档或者注释写的很好的话,可能花的时间会短 ...

  8. Java流式思想和方法引用

    目录 Java流式思想和方法引用 1. Stream流 1.1 概述 传统集合的多步遍历代码 Stream的更优写法 1.2 流式思想的概述 1.3 获取流 1.4 常用方法 ①逐一处理:forEac ...

  9. JAVA 流式布局管理器

    //流式布局管理器 import java.awt.*; import javax.swing.*; public class Jiemian2 extends JFrame{ //定义组件 JBut ...

  10. Spark流式编程介绍 - 编程模型

    来源Spark官方文档 http://spark.apache.org/docs/latest/structured-streaming-programming-guide.html#programm ...

随机推荐

  1. C语言中puts()和printf()区别

    puts的功能更加单一,只能输出字符串:printf的功能更加广,可以格式化数据,输出多种类型的数据. puts()函数用来向标准输出设备(屏幕)写字符串并换行. 调用方式为puts(string): ...

  2. 【C# 程序集】.net core 3.0中动态卸载|卸载程序集

    原文:https://docs.microsoft.com/zh-cn/dotnet/core/dependency-loading/understanding-assemblyloadcontext ...

  3. idea教程--Maven 骨架介绍

    简单的说,Archetype是Maven工程的模板工具包.一个Archetype定义了要做的相同类型事情的初始样式或模型.这个名称给我们提供来了一个一致的生成Maven工程的方式.Archetype会 ...

  4. 按照TomCat版本重新配置web.xml文件

    在TomCat的目录:C:\Program Files\Apache Software Foundation\Tomcat 9.0_Tomcat9.2\webapps\ROOT\WEB-INF下的we ...

  5. JZ-038-二叉树的深度

    二叉树的深度 题目描述 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 题目链接: 二叉树的深度 代码 /** * 标题:二叉 ...

  6. jq 页面添加布局

    要求: 1)实现如上图页面布局(10分) 2)实现选择城市所添加的内容追加到你喜欢哪个城市下(10分) 3)实现选择游戏所添加的内容追加到你喜欢哪款游戏下(10分) 4)新增的数据字体颜色设置为粉色( ...

  7. 输入URL到页面加载过程

    URL(uniform resource location) : 统一资源定位符,用来作为互联网上各种资源的标识符,可理解为身份证号 . 注意点:浏览器为了保证安全性,设定了跨域保护策略, 即窗口之间 ...

  8. 防止入侵 两步修改XP远程管理默认端口

    自Windows 2000开始,微软就提供一项终端服务(Terminal Server)这项服务可以将远程的桌面传递到本地.通过该服务,可视化的远程管理可以非常方便的实现.继Windows 2000之 ...

  9. DAViCal 跨站请求伪造漏洞

    受影响系统:DAViCal DAViCal <= 1.1.8描述:CVE(CAN) ID: CVE-2019-18346 DAViCal是一款日历共享服务器. DAViCal 1.1.8及之前版 ...

  10. 九鼎RK3399笔记一:Linux平台手册

    @ 目录 一.git下载九鼎SDK 二.安装所需的软件包: 三.安装 kernel 及 u-boot 编译需要依赖的软件包 四.安装文件系统需要依赖的软件包 五.安装 Buildroot 编译需要依赖 ...