Java 8 引入了流式操作(Stream),通过该操作可以实现对集合(Collection)的并行处理和函数式操作。用周阳大神的话说就是:SQL就是JAVA,JAVA就是SQL。使用java.util.stream包中的Stream接口即可完成SQL中的计算、order by、where等操作。根据操作返回的结果不同,流式操作分为中间操作和最终操作两种。最终操作返回一特定类型的结果,而中间操作返回流本身,这样就可以将多个操作依次串联起来。根据流的并发性,流又可以分为串行和并行两种。流式操作实现了集合的过滤、排序、映射等功能。
四大内置核心函数式接口
大部分函数式接口都不用我们自己写,Java 8都给我们写好了,这些接口都在java.util.function包里,下面简单介绍其中的几个。而在讲到Java 8中利用Stream的流式计算的时候,就不得不提及到java.util.function包中的四大函数式接口,分别是Function函数接口、Predicate函数式接口、Consumer函数式接口和Supplier函数式接口。
Function函数型函数式接口
Function接口为函数型接口,该接口的抽象方法接收一个参数并且做一些处理然后返回返回一个参数。其中T为接收参数类型,R为返回参数类型。
源码如下:其中的抽象方法为 R apply(T t)
Predicate断言型函数式接口
Predicate 用于做判断操作,所以抽象方法返回的是Boolean。
源码如下:抽象方法为: boolean test(T t)
Consumer消费型函数式接口
Consumer表示执行在单个参数上面的操作,但没有返回值的(正如消费有去无回)。
该类的源码如下:抽象方法为:void accept(T t)
Supplier供给型函数式接口
该接口不接受任何参数,返回一个任意泛型的值。
该类的源码如下:T get()
总结
Stream流式计算
流(Stream) 到底是什么呢?
是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。
“集合讲的是数据,流讲的是计算!”
特点
1、Stream 自己不会存储元素。
2、Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。
3、Stream 操作是延迟执行的。这意味着他们会等到需要结果的时候才执行。
如何使用
1、创建一个Stream:一个数据源(数组、集合)。(如list.stream()将List转换为Stream)
2、中间操作:一个中间操作,处理数据源数据。
3、终止操作:一个终止操作,执行中间操作链,产生结果。
示例代码如下:
package com.atguigu.juc.study;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.util.Arrays;
import java.util.List;
import java.util.UUID;
import java.util.function.*;
@Data
@NoArgsConstructor
@AllArgsConstructor
class User
{
private Integer id;
private String userName;
private int age;
}
/**
*
* 题目:请按照给出数据,找出同时满足
* 偶数ID且年龄大于24且用户名转为大写且用户名字母倒排序
* 最后只输出一个用户名字
*/
public class StreamDemo
{
public static void main(String[] args)
{
User u1 = new User(11,"a",23);
User u2 = new User(12,"b",24);
User u3 = new User(13,"c",22);
User u4 = new User(14,"d",28);
User u5 = new User(16,"e",26);
List<User> list = Arrays.asList(u1,u2,u3,u4,u5);
list.stream().filter(p -> {
return p.getId() % 2 == 0;
}).filter(p -> {
return p.getAge() > 24;
}).map(f -> {
return f.getUserName().toUpperCase();
}).sorted((o1, o2) -> {
return o2.compareTo(o1);
}).limit(1).forEach(System.out::println);
// R apply(T t);
Function<String,Integer> function = t -> {return t.length();};
System.out.println(function.apply("abc"));
// boolean test(T t);
Predicate<String> predicate = t -> {return t.startsWith("a");};
System.out.println(predicate.test("a"));
//void accept(T t);
Consumer<String> consumer = t -> {System.out.println(t);};
consumer.accept("java1018");
// T get();
Supplier<String> supplier = () -> {return UUID.randomUUID().toString();};
System.out.println(supplier.get());;
}
}