Java 8之流式计算

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());;
    }
}
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值