标签:传递 ati abs 介绍 tar parameter 格式 abstract 调用
前言:
这两天彻底的复习了一遍Java8的各种新特性,趁着热乎劲,把知识点整理成博客的形式保存一下。
Lambda表达式 : 也可称为闭包,Lambda允许把函数作为一个方法的参数(函数作为参数传递到方法中),免去了使用匿名方法的麻烦,并且给予Java简单但是强大的函数化的编程能力
语法格式:
(parameters) -> expression
或者
(parameters) ->{ statements; }格式说明:
():接口中抽象方法的参数列表,没有参数就空着,有参数则写出参数,多个参数用逗号分隔
->:传递的意思,将参数传递给方法体{}
{}:重写接口的抽象方法的方法体
()->10 //返回结果值:10
(String s)->System.out.print(s) //打印s的内容
//
a->a*10 //返回结果值:a*10(传入一个参数时,可以省略括号)
(a,b)->a*b //返回结果值:a*b(传入两个或以上参数时,不能省略括号,)
首先定义一个函数式接口 Calculator
,包含唯一一个抽象方法 Calcu()
public interface Calculator {
public abstract int Calcu(int x, int y);
}
其次定义一个 invokeCalcu()
,接收参数类型为接口
public static void invokeCalcu(int x, int y, Calculator calculator) {
int sum = calculator.Calcu(x, y);
System.out.println("sum = " + sum);
}
最后调用 invokeCalcu()
,一共有三种方法实现:
1)使用匿名内部类传入接口,并实现抽象方法
invokeCalcu(10, 20, new Calculator() {
@Override
public int Calcu(int x, int y) {
return x + y;
}
});
2)使用Lambda表达式,简化操作
invokeCalcu(120, 130, (a, b) -> a + b);
Runnable
//使用匿名内部类的方式实现多线程的创建
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("currentThreadName = " + Thread.currentThread().getName());
}
}).start();
//使用lambda表达式实现多线程
new Thread(() -> System.out.println("currentThread().getName() = " + Thread.currentThread().getName())).start();
接口中 有且仅有唯一一个抽象方法 ,称之为函数式接口(这种类型的接口也称为SAM接口,即Single Abstract Method interfaces)
使用前提:
- 使用Lambda必须具有接口,且要求接口中有且仅有一个抽象方法
- 无论是 JDK内置的
Runnable
、Comparator
接口还是自定义的接口,只有当接口中的抽象方法存在且唯一时,才可以使用Lambda- 使用Lambda必须具有上下文推断
方法的参数或局部变量类型必须为Lambda对应的接口类型,才能使用Lambda作为该接口的实例
有且仅有一个抽象方法的接口,称为
“函数式编程”
标签:传递 ati abs 介绍 tar parameter 格式 abstract 调用
原文地址:https://www.cnblogs.com/wuyiz/p/11863471.html