Lambda表达式,案例一:new Thread(() -> System.out.println("thread"));javascript
Lambda表达式,案例二:由参数/箭头和主体组成:java
(Apple a1, Apple a2) -> a1.getWeight().compareTo(a2.getWeight());
以前的代码形式:app
Comparator<Apple> byWeight = new Comparator<Apple>() {
public int compare(Apple a1, Apple a2) {dom
return a1.getWeight().compareTo(a2.getWeight());ide
}函数
}测试
针对这种情形,咱们怎么理解呢?其实很简单,上看一下上述lambda表达式的语法:() -> {}(): 括号就是接口方法的括号,接口方法若是有参数,也须要写参数。只有一个参数时,括号能够省略。-> : 分割左右部分的,没啥好讲的。{} : 要实现的方法体。只有一行代码时,能够不加括号,能够不写return。在控制台打印,不返回任何值(看起来像是返回void) ui
函数式接口就是只显式声明一个抽象方法的接口。为保证方法数量很少很多,java8提供了一个专用注解@FunctionalInterface
,这样,当接口中声明的抽象方法多于或少于一个时就会报错。以下图所示:this
步骤:spa
@FunctionalInterface public interface InterfaceWithNoParam { void run(); }
public class TestJava8{
//匿名内部类 InterfaceWithNoParam param1 = new InterfaceWithNoParam() { @Override public void run() { System.out.println("经过匿名内部类实现run()"); } }; //Lambda表达式 //空括号表示无参 InterfaceWithNoParam param = () -> System.out.println("经过Lambda表达式实现run()") ; }
@Test public void testIntfaceWithNoparam() { this.param.run(); this.param1.run(); }
上述内容实现了无参无返回值的函数接口与实现,固然还有其余形式:
@FunctionalInterface public interface InterfaceWithParams { void run(String s); }
InterfaceWithParams params = new InterfaceWithParams() { @Override public void run(String s) { System.out.println("经过" + s + "实现run(String)"); } }; InterfaceWithParams params1 = (String s) -> System.out.println("经过" + s + "实现run(String)");
this.params.run("匿名类"); this.params1.run("Lambda");
@FunctionalInterface public interface InterfaceUnVoidWithNoParam { String run(); }
InterfaceUnVoidWithNoParam interfaceUnVoidWithNoParam = new InterfaceUnVoidWithNoParam() { @Override public String run() { return "Hello World!"; } }; InterfaceUnVoidWithNoParam interfaceUnVoidWithNoParam1 = () -> "Hello Lambda!";
String s = this.interfaceUnVoidWithNoParam.run(); System.out.println("返回结果是:"+s); String s0 = this.interfaceUnVoidWithNoParam1.run(); System.out.println("返回结果是:"+s0);
@FunctionalInterface public interface InterfaceUnVoidWithParams { String run(Integer integer); }
InterfaceUnVoidWithParams interfaceWithParams = new InterfaceUnVoidWithParams() { @Override public String run(Integer integer) { return String.valueOf(integer); } }; InterfaceUnVoidWithParams interfaceWithParams1 = (Integer integer) -> String.valueOf(integer);
String s1 = this.interfaceWithParams.run(1); System.out.println("您输入的是:"+s1); String s2 = this.interfaceWithParams1.run(2); System.out.println("您输入的是:"+s2);
进一步深刻案例:
java.util.function中 Function, Supplier, Consumer, Predicate和其余函数式接口普遍用在支持lambda表达式的API中。这些接口有一个抽象方法,会被lambda表达式的定义所覆盖。
接口 | 参数 | 返回值 | 类别 | 示例 |
---|---|---|---|---|
Consumer | T | void | 消费型接口 | 输出一个值 |
Supplier | None | T | 供给型接口 | 工厂方法 |
Function | T | R | 函数型接口 | 得到 Artist 对象的名字 |
Predicate | T | boolean | 断言型接口 | 这张唱片已经发行了吗 |
Predicate接口:(断言型接口)
@FunctionalInterface
interface Predicate<T> {
boolean test(T t);
}
/**
* 执行Predicate判断
* @param age 年龄
* @param predicate Predicate函数式接口
* @return 返回布尔类型结果
*/
public static boolean doPredicate(int age, Predicate<Integer> predicate) {
return predicate.test(age);
}
//Predicate<Integer> predicate = (age) -> age >= 18?true:false;
public static void main(String[] args) {
boolean isAdult = doPredicate(20, x -> x >= 18);
System.out.println(isAdult);
}
}
supply接口类:(供给类)
public static List<Integer> supply(Integer num, Supplier<Integer> supplier){
List<Integer> resultList = new ArrayList<Integer>() ;
for(int x=0;x<num;x++)
resultList.add(supplier.get());
return resultList ;
}
public static void main(String[] args) {
List<Integer> list = supply(6,() -> (int)(Math.random()*100));
list.forEach(System.out::println);
}
消费型接口示例:
public
static
void
donation(Integer money, Consumer<Integer> consumer){
consumer.accept(money);
}
public
static
void
main(String[] args) {
donation(
1000
, money -> System.out.println(
"好心的麦乐迪为Blade捐赠了"
+money+
"元"
)) ;
}
public
static
Integer convert(String str, Function<String, Integer> function) {
return
function.apply(str);
}
public
static
void
main(String[] args) {
Integer value = convert(
"28"
, x -> Integer.parseInt(x));
}