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. 点云配准的端到端深度神经网络:ICCV2019论文解读

    点云配准的端到端深度神经网络:ICCV2019论文解读 DeepVCP: An End-to-End Deep Neural Network for Point Cloud Registration ...

  2. 计图MPI分布式多卡

    计图MPI分布式多卡 计图分布式基于MPI(Message Passing Interface),主要阐述使用计图MPI,进行多卡和分布式训练.目前计图分布式处于测试阶段. 计图MPI安装 计图依赖O ...

  3. 使用cookies,免密登录禅道(一)

    导言:在做自动化的过程中,很多时候都需要绕过登录验证码来进行测试,可使用cookie 绕过验证码进行登录. 以下以自己搭建的禅道环境登录为例(其他网站也可以同样道理): #coding=gbkimpo ...

  4. 分布式Jmeter压测机的部署

    部署 1.分布式配置 Master机Jmeter安装目录下/bin/jmeter.properties remote_hosts修改为slave压力机的IP 如 remote_hosts=10.0.4 ...

  5. 单点突破:Set

    HashSet HashSet存放的是散列值,它是按照元素的散列值来存取元素的. 元素的散列值通过hashCode方法计算 HashSet通过判断两个元素的Hash值是否相等,如果相等就会用equal ...

  6. 在模仿中精进数据分析与可视化01——颗粒物浓度时空变化趋势(Mann–Kendall Test)

      本文是在模仿中精进数据分析与可视化系列的第一期--颗粒物浓度时空变化趋势(Mann–Kendall Test),主要目的是参考其他作品模仿学习进而提高数据分析与可视化的能力,如果有问题和建议,欢迎 ...

  7. 【题解】滑雪 luogu1434 记忆化搜索

    记忆化搜索入门题 题目 Michael喜欢滑雪.这并不奇怪,因为滑雪的确很刺激.可是为了获得速度,滑的区域必须向下倾斜,而且当你滑到坡底,你不得不再次走上坡或者等待升降机来载你.Michael想知道在 ...

  8. 【floyd】8.29题解-path

    path 题目描述 这次的任务很简单,给出了一张有N个点M条边的加权有向无环图,接下来有Q个询问,每个询问包括2个节点X和Y,要求算出从X到Y的一条路径,使得密度最小(密度的定义为,路径上边的权值和除 ...

  9. Linux中查看网络命令

    tcp三次握手,所以一直在listening,在等待信号 udp是没有listening状态的,因为不管你在不在都会发信息给你. netstat -r  =route -n  可以查看路由

  10. Oracle简单分析

    1.Oracle 数据库是甲骨文公司开发的一种关系型数据库管理系统,也就是RDBMS(relational database management system). 2.Oracle 从头到尾都是一个 ...