package com.doctor.lambda;
import java.util.function.BinaryOperator;
import java.util.function.Consumer;
/**
* @author sdcuike
*
* Created on 2016年6月7日 上午12:03:18
*/
public class Demo1 {
public static void main(String[] args) {
Runnable runnable = () -> System.out.println("test lambda");
new Thread(runnable).start();
String msg = "hello ";
runnable = () -> {
System.out.println(msg);
System.out.println("run 1");
System.out.println("run 2");
};
new Thread(runnable).start();
Consumer<String> consumer = message -> System.out.println(message);
consumer.accept("hello java lambda ");
BinaryOperator<Long> add = (a, b) -> a + b;
System.out.println(add.apply(66L, 22L));
add = (Long a, Long b) -> a + b;
System.out.println(add.apply(66L, 33L));
}
}
以前,java中方法的参数大多为特殊的匿名类对象(接口内只有一个抽象方法 -Functional Interfaces -A functional interface is an interface with a single abstract method that is used as the type of a lambda expression.) 。java 的 Lambda 简化了语法,不必显示new 匿名类对象,而是(参数)->
{方法体} 的形式,参数如果只为一个参数,可以省去参数两侧的{},同样,方法体内只有一条语句,也可以省略{}。参数的类型同样可以省略,由编译器推导(实在推导不出,我们写上参数类型给编译器提示如何处理-Type
Inference),还是记住那句话:能省则省。 如果,方法体内使用了方法体外的变量,则这个变量编译器认为是final的,这和我们之前使用匿名类的规则一样,不过,java8语法对这一限制放松了,变量不必是final的,但必须是有效的final变量。