【Java】工作中常用的一些lambda表达式

lambda表达式

常用方法

foreach

相当于for循环遍历

public void testForEach(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};

        list.forEach(s-> System.out.println(s));
    }

Collect

将操作后的对象转换为新的对象

public static void testCollect(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("2");
        }};

        //转换为新的list
        List newList = list.stream().map(s -> Integer.valueOf(s)).collect(Collectors.toList());
        // 此处泛型会被抹掉 输出class java.util.ArrayList
        System.out.println(newList.getClass());
    }

Filter

满足filter表达式的内容会被留下来,不满足的会被过滤掉。

public static void testFilter() {
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};

        List<String> newList = list.stream()
            // 过滤掉我们希望留下来的值
            // 表示我们希望字符串是 1 能留下来
            // 其他的过滤掉
            .filter(str -> "1".equals(str))
            .collect(Collectors.toList());
        newList.forEach(s -> System.out.println(s));
    }

map

map 方法可以让我们进行一些流的转化,比如原来流中的元素是 A,通过 map 操作,可以使返回的流中的元素是 B

public void testMap() {
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};
        //通过 map 方法list中元素转化成 小写
        List<String> strLowerList = list.stream()
                .map(str -> str.toLowerCase())
                .collect(Collectors.toList());
    }

distinct

去重

public void testDistinct(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("2");
        }};
        list.stream()
                .map(s -> Integer.valueOf(s))
                .distinct()
                .collect(Collectors.toList());
    }

sorted

排序,可以在sorted里面自定义排序规则

public void testSorted(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};
        list.stream()
                .map(s -> Integer.valueOf(s))
                // 等同于 .sorted(Comparator.naturalOrder()) 自然排序
                .sorted()
                .collect(Collectors.toList());

        // 自定义排序器
        list.stream()
                .map(s -> Integer.valueOf(s))
                // 反自然排序
                .sorted(Comparator.reverseOrder())
                .collect(Collectors.toList());
    }

findFirst

findFirst 表示匹配到第一个满足条件的值就返回

public void testFindFirst(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("2");
        }};
        
        list.stream()
                .filter(s->"2".equals(s))
                .findFirst()
                .get();
        
        // 防止空指针
        list.stream()
                .filter(s->"2".equals(s))
                .findFirst()
                // orElse 表示如果 findFirst 返回 null 的话,就返回 orElse 里的内容
                .orElse("3");

        Optional<String> str= list.stream()
                .filter(s->"2".equals(s))
                .findFirst();
        // isPresent 为 true 的话,表示 value != null
        if(str.isPresent()){
            return;
        }
    }

Reduce

reduce 方法允许我们在循环里面叠加计算值

public void testReduce(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};
        
        list.stream()
                .map(s -> Integer.valueOf(s))
                // s1 和 s2 表示循环中的前后两个数
                .reduce((s1,s2) -> s1+s2)
                .orElse(0);

        list.stream()
                .map(s -> Integer.valueOf(s))
                // 第一个参数表示基数,会从 100 开始加
                .reduce(100,(s1,s2) -> s1+s2);
    }

Peek

在 peek 方法里面做任意没有返回值的事情,比如打印日志

public void testPeek(){
        List<String> list = new ArrayList<String>() {{
            add("1");
            add("2");
            add("3");
        }};
        list.stream().map(s -> Integer.valueOf(s))
                .peek(s -> System.out.println(s))
                .collect(Collectors.toList());
    }

如果链式调用中集合已经为空

如果链式调用中集合内容已经为空,此时最后结果不会报错,只是返回结果为空集合。

public static void testEmptyCollection() {
        List<String> testList = new ArrayList<>();
        testList.add("1");
        testList.add("2");
        testList.add("3");
        testList.add("4");
        Map<String, String> collect = testList.stream().filter(u -> "0".equals(u)).collect(Collectors.toMap(key -> key, value -> ""));
        System.out.println(collect);
    }

// {}

函数式接口

函数式接口参数类型返回类型方法名描述
SupplierTget产生一个类型为T的数据
ConsumerTvoidaccept消费一个类型为T的数据
BiConsumer<T,U>T,Uvoidaccept消费类型为T和类型为U的数据
Function<T,R>TRapply把参数类型为T的数据经过函数处理转换成类型为R的数据
BiFunction<T,U,R>T,URapply把参数类型为T和U的数据经过函数处理转换成类型为R的数据
UnaryOperatorTTapply对类型T进行了一元操作,仍返回类型T
BinaryOperatorT,TTapply对类型T进行了二元操作,仍返回类型T
PredicateTvoidtest对类型T进行函数处理,返回布尔值
BiPredicate<T,U>T,Uvoidtest对类型T和U进行函数处理,返回布尔值

Optional

Optional.ofNullable() 创建一个Optional,传入的值可以是null或不是null。

在这里插入图片描述

of() 方法,返回一个Optional对象。
在这里插入图片描述

empty() 方法:返回一个空的Optional方法

在这里插入图片描述
isPresent() 方法:判断是否有值

在这里插入图片描述

isPresent() 方法:如果有值就执行入参的lambda函数。

在这里插入图片描述

get() 方法:获取Optional的值,如果为空则抛出异常。

在这里插入图片描述

orElse() 方法:没有值时会返回指定的值。

在这里插入图片描述

orElseGet() 方法:

在这里插入图片描述

filter() 方法:用于过滤Optional中的值,若Optional中有值,且值满足过滤函数,则返回此Optional,否则返回空Optional.

map() 方法:用于转换值,若Optional有值,执行map中的lambda函数转换值。

Order order = getOrderById(orderId);
String userCode = Optional.ofNullable(order)
    .map(Order::getUser)
    .map(User::getUserCode)
    .map(String::toUpperCase)
    .orElse("")

其他知识点

  1. 如果lambda表达式已经有实现的方法了,则可以用方法引用进行简化。语法为:
  • 对象::实例方法
  • 类::静态方法
  • 类::实例方法
  1. 在Java的匿名内部类中,如果要引用外部变量,变量是需要声明为final的,虽然Lambda表达式的自由变量不用强制声明成final,但同样也是不允许修改的。原因

  2. lambda表达式原理

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值