Lambda表达式是对象,是一个函数式接口的实例,一般接口不能应用Lambda表达式。若想理解Lambda表达式及函数式接口介绍,请移步进行学习Java8 lambda表达式及自定义函数式接口入门。

Lambda 表达式语法

(lambda paramters) -> lambda expression;小括号():代表办法签名,当只有一个参数的时候,()能够省略lambda paramters:代表具体形参,参数能够指定类型也能够省略类型,因为Lambda表达式会主动推断出参数类型->:代表lambda操作符lambda expression:代表lambda表达式body体,具体的函数式接口惟一办法实现逻辑。当body体只有一行代码的时候,{}和return都能够省略

Lambda 表达式练习

要点:一看参数,二看返回值
\`
谬误示例:

参数类型要么全副省略,不能省略局部,如 (x, int y) -> x+y;
参数不能应用final润饰,如(final a)->a;
函数表达式接口不能返回一个Object对象,如Object obj = () -> "lambda";
不容许应用throws语句来申明它可能会抛出的异样,只能在办法上抛出异样,如
@Test
public void testCallable() throws Exception{
Callable callable = ()->{return 1;};
callable.call();
}
\`
无参无返回值
/** * 无参无返回值 */@Testpublic void testNoArgsNoReturn(){    /**     * 当大括号{}包含多行执行语句,则{}不能省略     */    Runnable t1 = () -> {        System.out.println("t1 running...");        System.out.println("t1 run ended.");    };    /**     * 当大括号{}只有一行执行语句,则{}能够省略,如下写法都正确     */    Runnable t2 = () -> {System.out.println("t2 running...");};    Runnable t3 = () -> System.out.println("t3 running...");    /**     * 当没有任何实现语句时,{}须要保留     */    Runnable t4 = () -> {};    new Thread(t1).start();    new Thread(t2).start();    new Thread(t3).start();    try {        Thread.sleep(1000);    } catch (InterruptedException e) {    }}
无参,有返回值
/** * 测试无参,有返回值 */@Testpublic void testNoArgsReturn() {    /**     * 当大括号{}包含多行执行语句,则{}不能省略     */    Supplier<String> s1 = () -> {        System.out.println("invoke get method");        return "lambda";    };    /**     * 当大括号{}只有一行执行语句,则{}能够省略,如下写法都正确     */    Supplier<String> s2 = () -> {        return "lambda";    };    Supplier<String> s3 = () -> "lambda";    /**     * 也能够返回null     */    Supplier<String> s4 = () -> null;    System.out.println(s1.get());    System.out.println(s2.get());    System.out.println(s3.get());    System.out.println(s4.get());}
有一个参数,无返回值
/** * 测试只有一个参数,无返回值 */@Testpublic void testArgsNoReturnValue(){    /**     *指定参数str 类型为String     */    Consumer<String> c0 = (String str)->{System.out.println("c0:"+str);};    /**     * 也能够不指定参数类型,会依据Consumer<String> 泛型主动推断接管的参数类型。     * 当只有一个参数时,参数局部的小括号能够省略,如下c1/c2写法都正确     */    Consumer<String> c1 = (str)->{System.out.println("c1:"+str);};    Consumer<String> c2 = str->{System.out.println("c2:"+str);};    c0.accept("lambda");    c1.accept("lambda");    c2.accept("lambda");}
有一个参数,有返回值
/** * 测试只有一个参数,有返回值场景 */@Testpublic void testArgsReturnValue() {    /**     * Function<Integer, String>用于接管一个参数,输入一个返回值     * 其中Integer示意输出参数类型,String示意返回值类型     */    Function<Integer, String> f1 = (Integer str) -> {        return "f1:"+String.valueOf(str);    };    /**     * 能够省略参数类型,省略大括号{}和return     */    Function<Integer, String> f2 = (str) -> {        return "f2:"+String.valueOf(str);    };    Function<Integer, String> f3 = (str) -> "f3:"+String.valueOf(str);    /**     * 因为只有一个参数,也能够省略小括号()     */    Function<Integer, String> f4 = str -> "f4:"+String.valueOf(str);    System.out.println(f1.apply(123));    System.out.println(f2.apply(124));    System.out.println(f3.apply(125));    System.out.println(f4.apply(126));}
多个参数,无返回值
/**     * 测试多个参数,无返回值场景     */    @Test    public void testMultiArgsNoReturn(){        /**         * BiConsumer<String,Integer> 用于接管2个不同类型的参数,泛型指定了两个参数的类型         * 因为参数多余1个,则小括号()不能省略         */        BiConsumer<String,Integer> b1 = (String str, Integer num)->{System.out.println("b1:"+str+num);};        /**         * 参数类型能够省略,要么全副省略参数类型,如(str, num)是能够的,         * 然而不能只省略一个类型则不能够,如(String str, num)或(str, Integer num)         */        BiConsumer<String,Integer> b2 = (str,  num)->{System.out.println("b2:"+str+num);};//        BiConsumer<String,String> b3 = (str,  num)->{System.out.println("b3:"+str+num);};        b1.accept("lambda",666);        b2.accept("lambda",666);    }
多个参数,有返回值
/** * 测试多个参数,有返回值场景 */@Testpublic void testMultiArgsReturnValue(){    /**     * BiFunction<String,String,Integer> 用于接管2个输出参数,输入一个返回值,输出和输入是不同类型     */    BiFunction<String,String,Integer> f1 = (String str1,String str2)->{return str1.length()+str2.length();};    /**     * BinaryOperator<Integer> 用于接管2个输出参数,输入一个返回值,输出和输入是雷同类型,是BiFunction的非凡状况     */    BinaryOperator<Integer> f11 = (Integer num1,Integer num2)->{return num1+num2;};    /**     * 省略参数类型     */    BiFunction<String,String,Integer> f2 = (str1, str2)->{return str1.length()+str2.length();};    BinaryOperator<Integer> f22 = (num1, num2)->{return num1+num2;};    /**     * 省略大括号{}和return ,必须同时省略     */    BiFunction<String,String,Integer> f3 = (str1,str2)->str1.length()+str2.length();    BinaryOperator<Integer> f33 = (num1, num2)->num1+num2;    System.out.println(f1.apply("java"," lambda"));    System.out.println(f2.apply("java"," lambda"));    System.out.println(f3.apply("java"," lambda"));    System.out.println(f11.apply(11,22));    System.out.println(f22.apply(11,22));    System.out.println(f33.apply(11,22));}

因为自己程度无限,如有谬误,欢送拍砖