1. Stream流

Stream流

1.1 体验Stream流

  

代码示例:

//需求:按照下面的要求完成集合的创建和遍历
public class StreamDemo {
public static void main(String[] args) {
// 1:创建一个集合,存储多个字符串元素
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); // 2:把集合中所有以"张“开头的元素存储到一个新的集合
ArrayList<String> zhangList = new ArrayList<String>();
// boolean startsWith(String prefix); 测试此字符串是否以指定的前缀开头。
for (String s : list) {
if (s.startsWith("张")) {
zhangList.add(s);
}
}
// System.out.println(zhangList); // 3:把"张"开头的集合中的长度为3的元素存储到一个新的集合
ArrayList<String> threeList = new ArrayList<String>();
for (String s : zhangList) {
if (s.length() == 3) {
threeList.add(s);
}
}
// System.out.println(threeList); // 4:遍历上一步得到的集合
for (String s : threeList) {
System.out.println(s);
}
System.out.println("---------------");
// Stream流来改进
// list.stream().filter(s -> s.startsWith("张")).filter(s -> s.length() == 3).forEach(s -> System.out.println(s));
list.stream().filter(s -> s.startsWith("张")).filter(s -> s.length() == 3).forEach(System.out::println);
}
}

运行结果:

  

1.2 Stream流的思想和生成方式

   

  

  

代码示例:

//Stream流的常见生成方式
public class StreamDemo01 {
public static void main(String[] args) {
// 1:Collection体系的集合可以使用默认方法stream ()生成流
// default Stream<E> stream ()
List<String> list = new ArrayList<String>();
Stream<String> listStream = list.stream(); Set<String> set = new HashSet<String>();
Stream<String> setStream = set.stream(); // 2:Map体系的集合间接的生成流
Map<String, Integer> map = new HashMap<String, Integer>();
// 使用key值间接生成Stream流
Stream<String> keyStream = map.keySet().stream();
// 使用value值间接生成Stream流
Stream<Integer> valueStream = map.values().stream();
// 使用键值对间接生成Stream流
Stream<Entry<String, Integer>> entryStream = map.entrySet().stream(); // 3:数组可以通过Stream接口的静态方法of (T... values)生成流
String[] strArray = { "hello", "world", "java" };
Stream<String> strArrayStream = Stream.of(strArray);
// 也可以直接使用参数生成Stream流
Stream<String> strArrayStream2 = Stream.of("hello", "world", "java");
// int类型也可以
Stream<Integer> streamStream3 = Stream.of(10, 20, 30); }
}

1.3 Stream流的常见中间操作方法

  

1.3.1 filter

filter(Predicate predicate):方法使用Predicate接口(Lambda表达式)过滤

  

代码示例:

public class StreamDemo02 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); // 需求1:把list集合中以张开头的元素在控制台输出
// list.stream().filter((String s) -> {
// return s.startsWith("张");
// }).forEach(System.out::println);
//使用简化的
list.stream().filter(s -> s.startsWith("张")).forEach(System.out::println);
System.out.println("---------------");
// 需求2:把list集合中长度为3的元素在控制台输出
list.stream().filter(s -> s.length() == 3).forEach(System.out::println);
System.out.println("---------------");
// 需求3:把list集合中以张开头的,长度为3的元素在控制台输出
list.stream().filter(s -> s.startsWith("张")).filter(s -> s.length() == 3).forEach(System.out::println);
}
}

运行结果:

  

1.3.2 limit && skip

limit(long maxSize):使用该方法可以截取maxSize个数据
skip(long n):使用该方法可以跳过n个数据

  

代码示例:

public class StreamDemo03 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); // 需求1:取前3个数据在控制台输出
list.stream().limit(3).forEach(System.out::println);
System.out.println("--------------------------");
// 需求2:跳过3个元素,把剩下的元素在控制台输出
list.stream().skip(3).forEach(System.out::println);
System.out.println("--------------------------");
// 需求3:跳过2个元素,把剩下的元素中前2个在控制台输出
list.stream().skip(2).limit(2).forEach(System.out::println);
}
}

运行结果:

  

1.3.3 concat && distinct

concat(Stream a,Stream b) :将a和b两个流合并
distinct():返回时将重复的元素去掉

  

代码示例:

public class StreamDemo04 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩");
list.add("张敏");
list.add("张无忌"); // 需求1:取前4个数据组成一个流
Stream<String> s1 = list.stream().limit(4);
// 需求2:跳过2个数据组成一个流
Stream<String> s2 = list.stream().skip(2);
// 需求3:合并需求1和需求2得到的流,并把结果在控制台输出
// Stream.concat(s1, s2).forEach(System.out::println);
// 需求4:合并需求1和需求2得到的流,并把结果在控制台输出,要求字符串元素不能重复
Stream.concat(s1, s2).distinct().forEach(System.out::println);
}
}

运行结果:

  

1.3.4 sorted() && sorted(Comparator comparator)

sorted():将结果安装自然规则排序
sorted(Comparator comparator):排序规则可以根据,Lambda表达式Comparator,自己定义

  

代码示例:

public class StreamDemo05 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("linqingxia");
list.add("zhangmanyu");
list.add("wangzuxian");
list.add("liuyan");
list.add("zhangmin");
list.add("zhangwuji"); // 需求1:按照字母顺序把数据在控制台输出
list.stream().sorted().forEach(System.out::println);
System.out.println("--------------------"); // 需求2:按照字符串长度把数据在控制台输出
list.stream().sorted((s1, s2) -> {
int num = s1.length() - s2.length();
int num2 = num == 0 ? s1.compareTo(s2) : num;
return num2;
}).forEach(System.out::println);
}
}

运行结果:

1.3.5 map && mapToInt

  

代码示例:

public class StreamDemo06 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("10");
list.add("20");
list.add("30");
list.add("40");
list.add("50"); // 需求:将集合中的字符串数据转换为整数之后在控制台输出
// <R>Stream<R> map (Function mapper): 返回由给定函数应用于此流的元素的结果组成的流
// list.stream().map(s -> Integer.parseInt(s)).forEach(System.out::println);
list.stream().map(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // 使用IntStream mapToInt (ToIntFunction mapper):
list.stream().mapToInt(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // int sum () 返回此流中元素的总和
// 该方法是是IntStream类独有的方法
int result = list.stream().mapToInt(Integer::parseInt).sum();
System.out.println(result); }
}

运行结果:

  

1.4 Stream流的常见终结操作方法

  
代码示例:

public class StreamDemo06 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("10");
list.add("20");
list.add("30");
list.add("40");
list.add("50"); // 需求:将集合中的字符串数据转换为整数之后在控制台输出
// <R>Stream<R> map (Function mapper): 返回由给定函数应用于此流的元素的结果组成的流
// list.stream().map(s -> Integer.parseInt(s)).forEach(System.out::println);
list.stream().map(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // 使用IntStream mapToInt (ToIntFunction mapper):
list.stream().mapToInt(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // int sum () 返回此流中元素的总和
// 该方法是是IntStream类独有的方法
int result = list.stream().mapToInt(Integer::parseInt).sum();
System.out.println(result); }
}

运行结果:

  

1.5 Stream流的练习

  
代码示例:

public class StreamDemo06 {
public static void main(String[] args) {
// 创建一个集合存储对个字符串
ArrayList<String> list = new ArrayList<String>();
list.add("10");
list.add("20");
list.add("30");
list.add("40");
list.add("50"); // 需求:将集合中的字符串数据转换为整数之后在控制台输出
// <R>Stream<R> map (Function mapper): 返回由给定函数应用于此流的元素的结果组成的流
// list.stream().map(s -> Integer.parseInt(s)).forEach(System.out::println);
list.stream().map(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // 使用IntStream mapToInt (ToIntFunction mapper):
list.stream().mapToInt(Integer::parseInt).forEach(System.out::println); System.out.println("----------------"); // int sum () 返回此流中元素的总和
// 该方法是是IntStream类独有的方法
int result = list.stream().mapToInt(Integer::parseInt).sum();
System.out.println(result); }
}

运行结果:

  

1.6 Stream流的收集操作(将数据收集到集合中)

  
代码示例:

public class CollertDemo {
public static void main(String[] args) {
// 创建List集合
ArrayList<String> list = new ArrayList<String>();
list.add("林青霞");
list.add("张曼玉");
list.add("王祖贤");
list.add("柳岩"); // 需求1:得到名字为3个字的流
Stream<String> listStream = list.stream().filter(s -> s.length() == 3); // 需求2:把使用Stream流操作完毕的数据收集到List集合中并遍历
List<String> listCollect = listStream.collect(Collectors.toList());
for (String s : listCollect) {
System.out.println(s);
} // 创建Set集合
Set<Integer> set = new HashSet<Integer>();
set.add(10);
set.add(20);
set.add(30);
set.add(33);
set.add(35);
System.out.println("-----------------");
// 需求3:得到年龄大于25的流
Stream<Integer> setStream = set.stream().filter(i -> i > 25);
// 需求4:把使用Stream流操作完毕的数据收集到Set集合中并遍历
Set<Integer> setCollect = setStream.collect(Collectors.toSet());
for (Integer i : setCollect) {
System.out.println(i);
}
System.out.println("-----------------");
// 定义一个字符串数组,每一个字符串数据由姓名数据和年龄数据组合而成
String[] strArray = { "林青霞,30", "张曼玉,35", "王祖贤,33", "柳岩,25" }; // 需求5:得到字符串中年龄数据大于28的流
Stream<String> arrayStream = Stream.of(strArray).filter(s -> Integer.parseInt(s.split(",")[1]) > 28); // 需求6:把使用Stream流操作完毕的数据收集到Map集合中并遍历,字符串中的姓名作键,年龄作值
Map<String, Integer> mapStream = arrayStream
.collect(Collectors.toMap((key -> key.split(",")[0]), value -> Integer.parseInt(value.split(",")[1]))); // 遍历mapStream
Set<String> keySet = mapStream.keySet();
for (String key : keySet) {
Integer value = mapStream.get(key);
System.out.println(key + "." + value);
} }
}

运行结果:

  

Java基础00-Stream流34的更多相关文章

  1. Java基础(十一) Stream I/O and Files

    Java基础(十一) Stream I/O and Files 1. 流的概念 程序的主要任务是操纵数据.在Java中,把一组有序的数据序列称为流. 依据操作的方向,能够把流分为输入流和输出流两种.程 ...

  2. java中的Stream流

    java中的Stream流 说到Stream便容易想到I/O Stream,而实际上,谁规定"流"就一定是"IO流"呢?在Java 8中,得益于Lambda所带 ...

  3. java基础之IO流(二)之字符流

    java基础之IO流(二)之字符流 字符流,顾名思义,它是以字符为数据处理单元的流对象,那么字符流和字节流之间的关系又是如何呢? 字符流可以理解为是字节流+字符编码集额一种封装与抽象,专门设计用来读写 ...

  4. java基础之IO流(一)字节流

    java基础之IO流(一)之字节流 IO流体系太大,涉及到的各种流对象,我觉得很有必要总结一下. 那什么是IO流,IO代表Input.Output,而流就是原始数据源与目标媒介的数据传输的一种抽象.典 ...

  5. Java 8创建Stream流的5种方法

    不知不觉间,Java已经发展到13了,来不及感慨时间过得真的太快了,来不及学习日新月异的技术更新,目前大多数公司还是使用的JDK8版本,一方面是版本的稳定,另一方面是熟悉,所以很多公司都觉得不升级也挺 ...

  6. Java基础之IO流整理

    Java基础之IO流 Java IO流使用装饰器设计模式,因此如果不能理清其中的关系的话很容易把各种流搞混,此文将简单的几个流进行梳理,后序遇见新的流会继续更新(本文下方还附有xmind文件链接) 抽 ...

  7. Java基础系列-Stream

    原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/10748817.html 一.概述 Stream操作简称流操作,这里的流与IO流毫无关系, ...

  8. Java基础:IO流之字节流和字符流

    1. 流的概念 流(stream)的概念源于UNIX中管道(pipe)的概念.在UNIX中,管道是一条不间断的字节流,用来实现程序或进程间的通信,或读写外围设备.外部文件等. 一个流,必有源端和目的端 ...

  9. Java 8 (3) Stream 流 - 简介

    什么是流? 流是Java API的新成员,它允许你以声明性方式处理数据集合(通过查询语言来表达,而不是临时编写一个实现).就现在来说你可以先把它当做是一个遍历数据集的高级迭代器.此外,流还支持并行,你 ...

  10. Java学习:Stream流式思想

    Stream流 Java 8 API添加了一种新的机制——Stream(流).Stream和IO流不是一回事. 流式思想:像生产流水线一样,一个操作接一个操作. 使用Stream流的步骤:数据源→转换 ...

随机推荐

  1. TVM 高效保护隐私 ML

    TVM 高效保护隐私 ML 这篇文章描述了Myelin,一个在值得信赖的硬件飞地中保护隐私的机器学习框架,以及TVM如何使Myelin快速.关键的想法是,TVM,不像其它流行的ML框架,将模型编译成轻 ...

  2. Jittor 的Op, Var算子

    Jittor 的Op, Var算子 要使用jittor训练模型,需要了解两个主要概念: Var:Jittor的基本数据类型 Operations:Jittor的算子与numpy类似 首先,开始使用Va ...

  3. Anchor Boxes示例实战

    Anchor Boxes示例实战 目标检测算法通常对输入图像中的大量区域进行采样,判断这些区域是否包含感兴趣的目标,并调整这些区域的边缘,以便更准确地预测目标的真实边界框.不同的模型可能使用不同的区域 ...

  4. C++中头文件和实现文件的关系

    头文件相当于是声明的集合,包括头文件的语句#Include实质为程序代码的宏替换. 编译阶段将函数和变量登记在符号表,链接时将各种函数的入口地址在其中查找到来调用,解引用.

  5. 类编程的WAF(下)

    一.编程语言的要素 天存信息的iWall3应用防火墙是一种创新式的类编程 WAF,它包含了编程语言的一些基本要素. 1. 变量 iWall3 中广义的变量包括报文变量.环境变量和用户变量:报文变量和环 ...

  6. 【带你手撸Spring】没有哪个框架开发,能离开 Spring 的 FactoryBean!

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 老司机,你的砖怎么搬的那么快? 是有劲?是技巧?是后门?总之,那个老司机的代码总是可 ...

  7. ceph-csi源码分析(2)-组件启动参数分析

    更多ceph-csi其他源码分析,请查看下面这篇博文:kubernetes ceph-csi分析目录导航 ceph-csi源码分析(2)-组件启动参数分析 ceph-csi组件的源码分析分为五部分: ...

  8. 17 DOS攻击防范

    #!/bin/bash source /etc/profile HOST_IP="172.16.1.122" DROP_IP_FILE="/tmp/drop_ip.log ...

  9. 21、nginx之ngx_http_proxy_module模块

    Nginx 的代理功能是通过 ngx_http_proxy_module 模块来实现的.默认在安装 Nginx 时已经安装了ngx_http_proxy_module模 块,因此可直接使用 ngx_h ...

  10. 41、解决du与df统计不一致的解决方法

    41.1.案例说明: 通过df -hT和du -sh /.du -h --max-depth=1 /命令 发现磁盘的使用不量不一致,使用'df -hT'命令查看磁盘的使用量要 比使用'du -sh / ...