lambda表达式总结---new Runnable和stream

1、示例1:启动线程

new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("test====>>>>");
            }
        });

Runnable接口为一个函数式接口,如下:只有一个抽象方法:

@FunctionalInterface
public interface Runnable {
    /**
     * When an object implementing interface <code>Runnable</code> is used
     * to create a thread, starting the thread causes the object's
     * <code>run</code> method to be called in that separately executing
     * thread.
     * <p>
     * The general contract of the method <code>run</code> is that it may
     * take any action whatsoever.
     *
     * @see     java.lang.Thread#run()
     */
    public abstract void run();
}

直接按alt+enter,idea直接会提示转为lambda表达式:
在这里插入图片描述
转化完如下:
new Thread(() -> System.out.println("test====>>>>"));
分析:由于该函数式接口只有一个方法,因此可以省略掉接口名称和方法名称;
2、stream流

  CustomerEntity customerEntity1 = new CustomerEntity("张三", "男", 15, new ArrayList<>());
        CustomerEntity customerEntity2 = new CustomerEntity("张三", "男", 15, new ArrayList<>());
        CustomerEntity customerEntity3 = new CustomerEntity("李四", "女", 20, new ArrayList<>());
        CustomerEntity customerEntity4 = new CustomerEntity("王五", "男", 23, new ArrayList<>());

        List<CustomerEntity> customerEntityList = new ArrayList<>();
        customerEntityList.add(customerEntity1);
        customerEntityList.add(customerEntity2);
        customerEntityList.add(customerEntity3);
        customerEntityList.add(customerEntity4);

        customerEntityList.stream().distinct().filter(new Predicate<CustomerEntity>() {
            @Override
            public boolean test(CustomerEntity customerEntity) {
                return customerEntity.getAge()>10;
            }
        }).forEach(new Consumer<CustomerEntity>() {
            @Override
            public void accept(CustomerEntity customerEntity) {
                System.out.println("年龄大于18同学的姓名"+customerEntity.getName());
            }
        });

stream()----list转化为流
distinct()----取重
filter()--------过滤 入参为函数式接口new Predicate,可以简化
forEach()—循环 入参为函数式接口new Consumer,可以简化
idea可以查看流的转化过程::

在这里插入图片描述
代码优化后:

        customerEntityList.stream().distinct().filter(customerEntity -> customerEntity.getAge()>18).forEach(customerEntity -> System.out.println("年龄大于18同学的姓名"+customerEntity.getName()));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值