0%

java | 函数式接口

ps: 2021-7-25 看到一篇很不错的文章,还没有整理,先放在下面。

函数式接口(Functional Interface)就是一个有且仅有一个抽象方法,但是可以有多个非抽象方法的接口。

函数式接口可以被隐式转换为 lambda 表达式。

函数式接口可以用 @FunctionalInterface 注解标识。

@FunctionalInterface

关于这个注解,可以查看我的博文。

已有的函数式接口

Lambda 表达式和方法引用(实际上也可认为是Lambda表达式)上。

如定义了一个函数式接口如下:

1
2
3
4
5
@FunctionalInterface
interface GreetingService
{
void sayMessage(String message);
}

那么就可以使用Lambda表达式来表示该接口的一个实现(注:JAVA 8 之前一般是用匿名类实现的):

1
GreetingService greetService1 = message -> System.out.println("Hello " + message);

函数式接口可以对现有的函数友好地支持 lambda

JDK 1.8 之前已有的函数式接口:

  • java.lang.Runnable
  • java.util.concurrent.Callable
  • java.security.PrivilegedAction
  • java.util.Comparator
  • java.io.FileFilter
  • java.nio.file.PathMatcher
  • java.lang.reflect.InvocationHandler
  • java.beans.PropertyChangeListener
  • java.awt.event.ActionListener
  • javax.swing.event.ChangeListener

JDK 1.8 新增加的函数接口:

  • java.util.function

java.util.function 它包含了很多类,用来支持 Java 的 函数式编程,该包中的函数式接口有:

序号 接口 & 描述
1 BiConsumer<T,U>
代表了一个接受两个输入参数的操作,并且不返回任何结果
2 BiFunction<T,U,R>
代表了一个接受两个输入参数的方法,并且返回一个结果
3 BinaryOperator
代表了一个作用于于两个同类型操作符的操作,并且返回了操作符同类型的结果
4 BiPredicate<T,U>
代表了一个两个参数的boolean值方法
5 BooleanSupplier
代表了boolean值结果的提供方
6 Consumer
代表了接受一个输入参数并且无返回的操作
7 DoubleBinaryOperator
代表了作用于两个double值操作符的操作,并且返回了一个double值的结果。
8 DoubleConsumer
代表一个接受double值参数的操作,并且不返回结果。
9 DoubleFunction
代表接受一个double值参数的方法,并且返回结果
10 DoublePredicate
代表一个拥有double值参数的boolean值方法
11 DoubleSupplier
代表一个double值结构的提供方
12 DoubleToIntFunction
接受一个double类型输入,返回一个int类型结果。
13 DoubleToLongFunction
接受一个double类型输入,返回一个long类型结果
14 DoubleUnaryOperator
接受一个参数同为类型double,返回值类型也为double 。
15 Function<T,R>
接受一个输入参数,返回一个结果。
16 IntBinaryOperator
接受两个参数同为类型int,返回值类型也为int 。
17 IntConsumer
接受一个int类型的输入参数,无返回值 。
18 IntFunction
接受一个int类型输入参数,返回一个结果 。
19 IntPredicate
:接受一个int输入参数,返回一个布尔值的结果。
20 IntSupplier
无参数,返回一个int类型结果。
21 IntToDoubleFunction
接受一个int类型输入,返回一个double类型结果 。
22 IntToLongFunction
接受一个int类型输入,返回一个long类型结果。
23 IntUnaryOperator
接受一个参数同为类型int,返回值类型也为int 。
24 LongBinaryOperator
接受两个参数同为类型long,返回值类型也为long。
25 LongConsumer
接受一个long类型的输入参数,无返回值。
26 LongFunction
接受一个long类型输入参数,返回一个结果。
27 LongPredicate
R接受一个long输入参数,返回一个布尔值类型结果。
28 LongSupplier
无参数,返回一个结果long类型的值。
29 LongToDoubleFunction
接受一个long类型输入,返回一个double类型结果。
30 LongToIntFunction
接受一个long类型输入,返回一个int类型结果。
31 LongUnaryOperator
接受一个参数同为类型long,返回值类型也为long。
32 ObjDoubleConsumer
接受一个object类型和一个double类型的输入参数,无返回值。
33 ObjIntConsumer
接受一个object类型和一个int类型的输入参数,无返回值。
34 ObjLongConsumer
接受一个object类型和一个long类型的输入参数,无返回值。
35 Predicate
接受一个输入参数,返回一个布尔值结果。
36 Supplier
无参数,返回一个结果。
37 ToDoubleBiFunction<T,U>
接受两个输入参数,返回一个double类型结果
38 ToDoubleFunction
接受一个输入参数,返回一个double类型结果
39 ToIntBiFunction<T,U>
接受两个输入参数,返回一个int类型结果。
40 ToIntFunction
接受一个输入参数,返回一个int类型结果。
41 ToLongBiFunction<T,U>
接受两个输入参数,返回一个long类型结果。
42 ToLongFunction
接受一个输入参数,返回一个long类型结果。
43 UnaryOperator
接受一个参数为类型T,返回值类型也为T。

举个栗子

Consumer

接口唯一的抽象方法是:

1
void accept(T t);

这是一个单参数,无返回值的方法,参数是泛型类。这个接口被称为消费型接口,因为没有返回值,接口里面干了什么和调用方没什么关系。

这种单参数无返回值的接口我们可以这么用Lambda表达式:

1
2
3
4
5
6
7
8
import java.util.function.Consumer;

public class Test {
public static void main(String[] args) {
Consumer consumer = (a) -> System.out.println("this is " + a);
consumer.accept("123");
}
}

输出的结果是:

this is 123

Supplier

接口唯一的抽象方法是:

1
T get();

这是一个无参数,有返回值的方法,返回值类型是泛型类。这个接口被称作供给型接口。

这种无参数有返回值的方法我们可以这么用:

1
2
3
4
5
6
7
8
9
import java.util.function.Supplier;

public class Test {
public static void main(String[] args) {
Supplier<String> supplier = () -> "abc";
String result = supplier.get();
System.out.println(result);
}
}

ToIntFunction

接口唯一的抽象方法是:

1
int applyAsInt(T value);

这是一个单参数,返回值为int的方法,参数类型是泛型类。

使用例子:

1
2
3
4
5
6
7
8
9
10
11
import java.util.function.ToIntFunction;

public class Test {
public static void main(String[] args) {
ToIntFunction<String> toIntFunction = (a) -> {
return Integer.parseInt(a);
};
int result = toIntFunction.applyAsInt("123");
System.out.println(result);
}
}
请我喝杯咖啡吧~