Java提升四:Stream流
1、Stream流的定义
Stream是Java中的一个接口。它的作用类似于迭代器,但其功能比迭代器强大,主要用于对数组和集合的操作。
Stream中的流式思想:每一步只操作,不存储。
2、Stream流的获取
可以获取Stream流的有数组和集合。对于数组而言,获取Stream流的方式如下:
StreamMethodCount of(数组)
代码示例:
//数组变为Stream流
int[] arr={1,2,3,4,5,6,7};
Stream<int[]> stream = Stream.of(arr);
对于集合而言,获取Stream流的方式如下:
集合.stream()
代码示例:
//把集合转换为Stream流
List<String> list=new ArrayList<>();
Stream<String> stream1=list.stream();
Set<String> set=new HashSet<>();
Stream<String> stream2=set.stream();
Map<String,Integer> map=new HashMap<>();
//获取键,存储到Set中
Set<String> key_set=map.keySet();
Stream<String> stream3=key_set.stream();
//获取值,存储到collection集合中
Collection<Integer> values=map.values();
Stream<Integer> stream4 = values.stream();
//获取键值对
Set<Map.Entry<String, Integer>> entries = map.entrySet();
Stream<Map.Entry<String, Integer>> stream5 = entries.stream();
3、对于Stream流进行操作的方法
当数组和集合转化为Stream流之后,可以直接使用Stream流中定义好的方法对于原始的数组和集合进行遍历和过滤等一系列操作,从而使其更加简洁方便。Stream 流自身可以调用的方法大致可以分为两类:
(1)终结方法:返回值不再是stream接口自身类型的方法。
(2)延迟方法:stream流调用该类方法后得到的返回值还是一个Stream流,
故而使用此类方法可以实现链式调用。
3.1、终结方法
3.1.1、forEach方法
该方法的具体定义如下:void forEach(Consumer<? super T> action);
该方法返回值为空,故而在终结方法之列。
该方法要求传入参数是对于函数式接口Consumer的实现类,实现方式可使用匿名内部类、lambda表达式以及方法引用来实现。
关于该函数式接口的具体使用可以参考我写过的上一篇博文: link.
在此处只对其功能做简要介绍。
Consume接口中的唯一的抽象式方法是为了接受给定类型数据,并使用所得到的的数据。
该方法的主要作用是:对流中的元素进行遍历。
代码示例:
public static void main(String[] args) {
//获取Stream流
Stream<String> stream = Stream.of("jay","jj","vae");
//使用Stream流的方法forEach对流进行遍历
stream.forEach((String name)->{
System.out.println(name);//输出结果:jay,jj,vae
});
}
此处对于函数式接口Consume的实现采用的是lambda表达式方法,以下再次出现时就不在重复介绍。
3.1.2、count方法
该方法的具体定义如下:long count();
该方法返回值为long类型的整数,故而在终结方法之列。
该方法无需传参。
该方法的主要作用是:对流中的元素的总个数进行统计。
代码示例:
public static void main(String[] args) {
//获取一个Stream流
List<Integer> list=new ArrayList<>();
list.add(1);
list.add(2);
list.add(3);
list.add(4);
list.add(5);
list.add(6);
list.add(7);
Stream<Integer> stream1 = list.stream();
long count1 = stream1.count();
System.out.println(count1);//输出结果为:7
}
3.2、延迟方法
该类方法的最重要的一个性质就是可以进行链式调用,提升数据处理效率。
3.2.1、filter方法
该方法的具体定义如下: Stream filter(Predicate<? super T> predicate);
该方法返回值为Stream类型,故而在延迟方法之列。
该方法要求传入参数是对于函数式接口Predicate的实现类,实现方式可使用匿名内部类、lambda表达式以及方法引用来实现。
关于该函数式接口的具体使用可以参考我写过的上一篇博文: link.
在此处只对其功能做简要介绍。
Predicate接口中的唯一的抽象式方法是为了对比接受数据类型和要求类型是否一致,并根据结果返回boolean值
该方法的主要作用是:对流中的元素按照某种规则进行筛选后得到一个新的流。其功能等价于一个for循环语句+一个条件判断语句。
代码示例:
public static void main(String[] args) {
//创建一个流
Stream<String> stream = Stream.of("朱元璋", "李世民", "张三丰", "周芷若", "赵敏");
//对流中的元素进行过滤,只要姓张的
Stream<String> stream2 = stream.filter((String name)->{
return name.startsWith("张");
});
stream2.forEach((name)->{
System.out.println(name);//输出结果:"张三丰"
});
}
3.2.2、concat方法
该方法的具体定义如下: Stream concat(Stream<? extends T> a, Stream<? extends T> b)
该方法返回值为Stream类型,故而在延迟方法之列。
该方法要求传入参数两个Stream流。
该方法的主要作用是:将两个Stream流整合为一个Stream流。
代码示例:
public static void main(String[] args) {
Map<String,String> map=new HashMap<>();
map.put("张无忌","赵敏");
map.put("宋青书","周芷若");
map.put("灭绝师太","圆空");
map.put("黄晓明","章金莱");
map.put("孙悟空","白骨精");
map.put("猪八戒","嫦娥");
Set<String> setKey = map.keySet();
Collection<String> values = map.values();
Stream<String> stream1 = setKey.stream();
Stream<String> stream2 = values.stream();
Stream<String> concatStream = Stream.concat(stream1, stream2);
concatStream.forEach((s)->{
System.out.println(s);//输出结果过长,就不再一一赘述
});
3.2.3、map方法
该方法的具体定义如下:Stream map(Function<? super T, ? extends R> mapper);
该方法返回值为Stream类型,故而在延迟方法之列。
该方法要求传入参数是对于函数式接口Function的实现类,实现方式可使用匿名内部类、lambda表达式以及方法引用来实现。
关于该函数式接口的具体使用可以参考我写过的上一篇博文: link.
在此处只对其功能做简要介绍。
Function接口中的唯一的抽象式方法是为了将接受数据的类型转化为另一个类型。
该方法的主要作用是:将一个流中的元素映射到另一个流中。
代码示例:
public static void main(String[] args) {
//获取Stream流
Stream<String> stringStream = Stream.of("1", "2", "3", "4");
//使用map方法,将字符串类型转化为int型
Stream<Integer> stream=stringStream.map((String s)->{
return Integer.parseInt(s);
});
stream.forEach((i)->{
System.out.println(i);
});
}
3.2.4、limit方法
该方法的具体定义如下: Stream limit(long maxSize);
该方法返回值为Stream类型,故而在延迟方法之列。
该方法要求传入的参数是要截取给定Stream流的前多少个元素的数目。
该方法的主要作用是:用于截取给定Stream流中的元素,从而形成一个新的流。
代码示例:
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("李");
list.add("张");
list.add("许");
list.add("王");
list.add("朱");
Stream<String> stream = list.stream();
//limit方法
Stream<String> limitStream = stream.limit(3);
limitStream.forEach((s)->{
System.out.println(s);//输出结果:李、张、王
});
}
3.2.5、skip方法
该方法的具体定义如下: Stream skip(long maxSize);
该方法返回值为Stream类型,故而在延迟方法之列。
该方法要求传入的参数是要跳过给定Stream流的前多少个元素的数目。
该方法的主要作用是:用于跳过给定Stream流中前几个元素,从而形成一个新的流。
代码示例:
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("李");
list.add("张");
list.add("许");
list.add("王");
list.add("朱");
Stream<String> stream = list.stream();
//skip方法
Stream<String> skipStream = stream.skip(3);
try{
skipStream.forEach((s1)->{
System.out.println(s1);//输出结果:王、朱
});
}catch (Exception e){
e.printStackTrace();
}
}
4、总结
Stream流主要是对于集合和数组的遍历操作做了一系列改进。
将集合和数组转化为stream流后,结合stream中已经定义好的各种方法,可以更加简洁的对于数组和结合中的元素进行操作。
当以后需要遍历一个集合和数组之前,不妨想想使用stream流会不会更合适。
Java提升四:Stream流的更多相关文章
- Java 8创建Stream流的5种方法
不知不觉间,Java已经发展到13了,来不及感慨时间过得真的太快了,来不及学习日新月异的技术更新,目前大多数公司还是使用的JDK8版本,一方面是版本的稳定,另一方面是熟悉,所以很多公司都觉得不升级也挺 ...
- java中的Stream流
java中的Stream流 说到Stream便容易想到I/O Stream,而实际上,谁规定"流"就一定是"IO流"呢?在Java 8中,得益于Lambda所带 ...
- Java 8 (6) Stream 流 - 并行数据处理与性能
在Java 7之前,并行处理集合非常麻烦.首先你要明确的把包含数据的数据结构分成若干子部分,然后你要把每个子部分分配一个独立的线程.然后,你需要在恰当的时候对他们进行同步来避免竞争,等待所有线程完成. ...
- Java学习:Stream流式思想
Stream流 Java 8 API添加了一种新的机制——Stream(流).Stream和IO流不是一回事. 流式思想:像生产流水线一样,一个操作接一个操作. 使用Stream流的步骤:数据源→转换 ...
- Java 8 (3) Stream 流 - 简介
什么是流? 流是Java API的新成员,它允许你以声明性方式处理数据集合(通过查询语言来表达,而不是临时编写一个实现).就现在来说你可以先把它当做是一个遍历数据集的高级迭代器.此外,流还支持并行,你 ...
- 双层for循环用java中的stream流来实现
//双重for循环for (int i = 0; i < fusRecomConfigDOList.size(); i++) { for (int j = 0; j < fusRecomC ...
- Java 8 (5) Stream 流 - 收集数据
在前面已经使用过collect终端操作了,主要是用来把Stream中的所有元素结合成一个List,在本章中,你会发现collect是一个归约操作,就像reduce一样可以接受各种做法作为参数,将流中的 ...
- Java 8 (4) Stream 流 - 使用
在本节中将介绍Stream API支持的许多操作,这些操作可以完成更复杂的数据查询,如筛选.切片.映射.查找.匹配和归约.还有一些特殊的流如:数值流.来自文件和数组等多种来源的流. 筛选和切片 1.用 ...
- java 数据类型:Stream流 对象转换为集合collect(Collectors.toList()) ;常用方法count,limit,skip,concat,max,min
集合对象.stream() 获取流对象,对元素批处理(不改变原集合) 集合元素循环除了用for循环取出,还有更优雅的方式.forEach 示例List集合获取Stream对象进行元素批处理 impor ...
随机推荐
- 4.ORM框架的查询
创建表对应关系代码如下: from flask import Flask, render_template from flask_sqlalchemy import SQLAlchemy app=Fl ...
- 数据包报文格式(IP包、TCP报头、UDP报头)
转自: https://blog.51cto.com/lyhbwwk/2162568 一.IP包格式 IP数据包是一种可变长分组,它由首部和数据负载两部分组成.首部长度一般为20-60字节(Byte) ...
- oracle查询连续n天登录的用户
-- 查询连续3天登录的用户 1 先创建一个表,如下: create table USER_DATA ( USER_ID NUMBER, LOGIN_TIME DATE ); 2 插入用户登录数据: ...
- 了解 C++
C++的历史 C++由C语言发展演变而来,最初被称为"带类的C" 1983年正式取名为C++ 1998年11月被国籍标准化组织(ISO)批准为国际标准 2003年10月15日发布了 ...
- 5-create-react-app整合antDesign功能
使用ant-design: 首先创建react项目: create-react-app app cd app 其次 AntDesign的高级配置:按需导入组件,自定义主题 1.下载依赖(利用yarn, ...
- ➡️➡️➡️leetcode 需要每天打卡,养成习惯
目录 待完成的 完成的 0204 0203 以前 java 的 ! 的操作 不像 c 那样自由,!不要使用在int 变量上 c ^ 是异或操作 体会:c中,malloc 后的新建的数组,默认不是0(j ...
- IELTS Simon wr task p3
- 本周总结(19年暑假)—— Part2
日期:2019.7.21 博客期:108 星期日 这几天正在认真学习大数据,我是在B站上看尚老师的视频搞得.我已经配好了Hadoop的基本环境,现在学习的是HDFS的相关内容
- openstack的一台Nova主机上的虚拟机网络的配置
1.一台虚拟机器的网络配置,通过openstack/nova计算节点服务生成的虚拟机配置文件 <interface type='bridge'> <mac address='fa:1 ...
- Java经典算法50道题
[程序1]题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 月 数量 1 1 2 ...