lambda表达式

package com.qian;

import java.util.Comparator;

import org.junit.Test;

/**
 * Lambda 表达式的使用举例
 * 
 */
public class LambdaTest {

    @Test
    public void test1() {

        Runnable r1 = new Runnable() {
            @Override
            public void run() {
                System.out.println("我爱北京天安门");
            }
        };

        r1.run();

        System.out.println("*** *** ***");

        Runnable r2 = () -> System.out.println("故宫我所爱");

        r2.run();
    }

    @Test
    public void test2() {

        Comparator<Integer> com1 = new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return Integer.compare(o1, o2);
            }
        };

        int compare1 = com1.compare(12, 21);
        System.out.println(compare1);

        System.out.println("*** *** *** ***");

        // Lambda 表达式的写法
        Comparator<Integer> com2 = (o1, o2) -> Integer.compare(o1, o2);

        int compare2 = com2.compare(32, 21);
        System.out.println(compare2);

        System.out.println("*** *** *** *** ***");
        // 方法引用
        Comparator<Integer> com3 = Integer::compare;

        int compare3 = com2.compare(32, 21);
        System.out.println(compare3);
    }
}

package com.qian;

import java.util.ArrayList;
import java.util.Comparator;
import java.util.function.Consumer;

import org.junit.Test;

/**
 * Lambda 表达式的使用
 * 
 * 1.举例:(o1,o2) -> Integer.compare(o1,o2);
 * 
 * 2.格式:
 * 
 * ......-> : lambda 操作符 或 箭头操作符
 * 
 * ......->左边 : lambda 形参列表 (其实就是接口中的抽象方法的形参列表)
 * 
 * ......->右边 : lambda 体(其实就是重写的抽象方法的方法体)
 * 
 * 3.Lambda 表达式的使用:(分为 6 种情况)
 * 
 * 总结:
 * 
 * -> 左边:lambda 形参列表的参数类型可以省略(类型推断):如果 lambda 形参列表只有一个参数,其一对()也可以省略
 * 
 * -> 右边:lambda 体应该使用一对{}包裹;如果 lambda 体只有一条执行语句(可能是 return 语句),可以省略这一对 {} 和 return 关键字({}省略 return 必须省略)
 * 
 * 4.Lambda 表达式的本质:作为接口的实例
 * 
 * 5.如果一个接口中,只声明了一个抽象方法,则此接口就称为函数式接口。我们可以在一个接口上使用 @FunctionalInterface 注解,
 * 
 * ..这样做可以检查它是否是一个函数是接口。
 * 
 * 6.所以以前用匿名实现类表示的现在都可以用 Lambda 表达式来写。
 * 
 * @author 21115 @ date 2021/9/7
 */
public class LambdaTest1 {

    // 语法格式一:无参,无返回值
    @Test
    public void test1() {

        Runnable r1 = new Runnable() {
            @Override
            public void run() {
                System.out.println("我爱北京天安门");
            }
        };

        r1.run();

        System.out.println("*** *** ***");

        Runnable r2 = () -> {
            System.out.println("故宫我所爱");
        };

        r2.run();
        // 我爱北京天安门
        // *** *** ***
        // 故宫我所爱

    }

    // 语法格式二:Lambda 需要一个参数,但是没有返回值
    @Test
    public void test2() {
        Consumer<String> con = new Consumer<String>() {
            @Override
            public void accept(String s) {
                System.out.println(s);
            }
        };
        con.accept("谎言和誓言的区别是什么?");

        System.out.println("*** *** *** *** ***");

        Consumer<String> con1 = (String s) -> {
            System.out.println(s);
        };
        con1.accept("一个是听得人当真了,一个是说得人当真了");

        // 谎言和誓言的区别是什么?
        // *** *** *** *** ***
        // 一个是听得人当真了,一个是说得人当真了
    }

    // 语法格式三:数据类型可以省略,因为可由编译器推断得出,称为"类型推断"
    @Test
    public void test3() {

        Consumer<String> con1 = (String s) -> {
            System.out.println(s);
        };
        con1.accept("一个是听得人当真了,一个是说得人当真了");

        System.out.println("*** *** *** *** ***");

        Consumer<String> con2 = (s) -> {
            System.out.println(s);
        };
        con2.accept("一个是听得人当真了,一个是说得人当真了");
        // 一个是听得人当真了,一个是说得人当真了
        // *** *** *** *** ***
        // 一个是听得人当真了,一个是说得人当真了
    }

    @Test
    public void test4() {

        // 类型推断
        ArrayList<String> list = new ArrayList<>();

        // 类型推断
        int[] arr = {1, 2, 3};
    }

    // 语法格式四:Lambda 若只需要一个参数时,参数的小括号可以省略
    @Test
    public void test5() {
        Consumer<String> con1 = (s) -> {
            System.out.println(s);
        };
        con1.accept("一个是听得人当真了,一个是说得人当真了");

        System.out.println("*** *** *** *** ***");

        Consumer<String> con2 = s -> {
            System.out.println(s);
        };
        con2.accept("一个是听得人当真了,一个是说得人当真了");
        // 一个是听得人当真了,一个是说得人当真了
        // *** *** *** *** ***
        // 一个是听得人当真了,一个是说得人当真了
    }

    // 语法格式五:Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值
    @Test
    public void test6() {
        Comparator<Integer> com1 = new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                System.out.println(o1);
                System.out.println(o2);
                return o1.compareTo(o2);
            }
        };

        System.out.println(com1.compare(12, 21));

        System.out.println("*** *** *** ***");
        // Lambda 表达式的写法
        Comparator<Integer> com2 = (o1, o2) -> {
            System.out.println(o1);
            System.out.println(o2);
            return o1.compareTo(o2);
        };
        System.out.println(com2.compare(12, 6));
        // 12
        // 21
        // -1
        // *** *** *** ***
        // 12
        // 6
        // 1
    }

    // 语法格式六:当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略
    @Test
    public void test7() {
        Comparator<Integer> com1 = (o1, o2) -> {
            return o1.compareTo(o2);
        };

        System.out.println(com1.compare(12, 6));

        System.out.println("*** *** *** *** ***");

        Comparator<Integer> com2 = (o1, o2) -> o1.compareTo(o2);

        System.out.println(com2.compare(12, 21));
        // 1
        // *** *** *** *** ***
        // -1
    }

    @Test
    public void test8() {
        Consumer<String> con1 = s -> {
            System.out.println(s);
        };
        con1.accept("一个是听得人当真了,一个是说得人当真了");

        System.out.println("*** *** *** *** ***");

        Consumer<String> con2 = s -> System.out.println(s);

        con2.accept("一个是听得人当真了,一个是说的人当真了");
        // 一个是听得人当真了,一个是说得人当真了
        // *** *** *** *** ***
        // 一个是听得人当真了,一个是说的人当真了
    }
}

package com.qian;

/**
 * 什么是函数式(Functional)接口
 * 
 * 1.只包含一个抽象方法得接口,称为函数式接口。
 * 
 * 2.你可以通过 Lambda 表达式来创建该接口的对象。(若 Lambda 表达式抛出一个受检异常(即:非运行时异常),那么该异常需要在目标接口的抽象方法上进行声明)。
 * 
 * 3.我们可以在一个接口上使用 @Functionallnterface 注解,这样做可以检查它是否是一个函数式接口。同时 javadoc 也会包含一条声明,说明这个接口是一个函数式接口。
 * 
 * 4.在 java.util.function 包下定义了 Java 8 的丰富的函数式接口
 * 
 * 
 * Java内置四大核心函数式接口
 * 
 * 函数式接口...............参数类型...............返回类型...............用途
 * 
 * Consumer<T>消费型接口......T...................void.................对类型为 T 的对象应用操作,包含方法:void accept(T t)
 * 
 * Supplier<T>供给型接口.....无.....................T..................返回类型为 T 的对象,包含方法:T get()
 * 
 * Function<T,R>函数型接口...T.....................R...................对类型为 T 的对象应用操作,并返回结果。结果是 R 类型的对象。包含方法:R apply(T t)
 * 
 * Predicate<T>断定型接口....T.....................boolean.............确定类型为 T 的对象是否满足某约束,并返回 boolean 值。包含方法:boolean test(T
 * t)
 * 
 */
@FunctionalInterface
public interface MyInterface {

    void method1();
    // void method2();

}

package com.qian;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.function.Consumer;
import java.util.function.Predicate;

import org.junit.Test;

/**
 * java内置的 4 大核心函数式接口
 * 
 * 消费型接口 Consumer<T> void accept(T t)
 * 
 * 供给型接口 Supplier<T> T get()
 * 
 * 函数型接口 Function<T,R> R apply(T t)
 * 
 * 断定型接口 Predicate<T> boolean test(T t)
 * 
 */
public class LambdaTest2 {

    @Test
    public void test1() {

        happyTime(500, new Consumer<Double>() {
            @Override
            public void accept(Double aDouble) {
                System.out.println("学习太累了,去天上人间买了瓶矿泉水,价格为: " + aDouble);
            }
        });

        System.out.println("*** *** *** *** ***");

        happyTime(400, money -> System.out.println("学习太累了,去天上人间喝了口矿泉水,价格为: " + money));
    }

    public void happyTime(double money, Consumer<Double> con) {
        con.accept(money);
    }
    // 学习太累了,去天上人间买了瓶矿泉水,价格为: 500.0
    // *** *** *** *** ***
    // 学习太累了,去天上人间喝了口矿泉水,价格为: 400.0

    @Test
    public void test2() {
        List<String> list = Arrays.asList("北京", "南京", "天津", "东京", "西京", "普京");
        List<String> filterStrs = filterString(list, new Predicate<String>() {
            @Override
            public boolean test(String s) {
                return s.contains("京");
            }
        });
        System.out.println(filterStrs);
        // [北京, 南京, 东京, 西京, 普京]

        List<String> filterStrs1 = filterString(list, s -> s.contains("京"));
        // [北京, 南京, 东京, 西京, 普京]
        System.out.println(filterStrs1);
    }

    // 根据给定的规则,过滤集合中的字符串。此规则由 Predicate 的方法决定
    public List<String> filterString(List<String> list, Predicate<String> pre) {

        ArrayList<String> filterList = new ArrayList<>();
        for (String s : list) {
            if (pre.test(s)) {
                filterList.add(s);
            }
        }
        return filterList;
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值