1,函数式接口介绍
前言:由于Java8中引入了lambda表达式语法,但该语法需要配合一种特定的接口才能使用,由此产生出了函数式接口;
函数式接口指有且仅有一个抽象方法(由Object对象继承的方法不算)(但可以有多个默认方法和静态方法)的接口,当这样的接口在作为方法参数时可以隐式的转换为lambda表达式;但是在实际项目中函数式接口表现得非常脆弱(举个例子:由20人组成的开发小组负责一个项目,某一天小组成员小明在写代码时抽象了一个方法,并写在了一个独立的接口里面,然后开始使用lambda表达式来应用于该接口为方法参数时的情况,经过一段时间,小明已经在很多地方都对该接口为方法参数的地方使用了lambda表达式,突然有一天另外一位同事觉得该接口需要再新增一个抽象方法,于是他加了之后导致小明之前所有对该接口使用了lambda表达式的地方都编译错误...),所以Java8也提供了一个标计在接口上的注解@FunctionalInterface
去显示说明该接口是函数式接口;
public class LambdaTest {
private Integer a;
public LambdaTest(Integer a) {
this.a = a;
}
public void print(LambdaInterface lambdaInterface) {
lambdaInterface.print(this.a);
}
public static void main(String[] args) {
LambdaTest lambdaTest = new LambdaTest(123);
lambdaTest.print(a -> System.out.println("a: " + a));
}
}
/**
* 自定义函数式接口
*/
@FunctionalInterface
interface LambdaInterface {
void print(Integer a);
/**
* 继承于Object类不算
*/
boolean equals(Object obj);
/**
* 允许有默认方法
*/
default void defaultMethod() {
}
/**
* 允许有静态方法
*/
static void staticMethod() {
}
}
2,java8中提供的函数式接口
- java.lang.Runnable
package java.lang;
@FunctionalInterface
public interface Runnable {
public abstract void run();
}
- java.util.concurrent.Callable
package java.util.concurrent;
@FunctionalInterface
public interface Callable<V> {
V call() throws Exception;
}
- java.util.Comparator
package java.util;
@FunctionalInterface
public interface Comparator<T> {
int compare(T o1, T o2);
......
}
- java.util.function包下所以接口都是函数式接口
原文链接:https://blog.csdn.net/gu19930914/article/details/115702463
标签:java,函数,void,接口,Java8,public,lambda From: https://www.cnblogs.com/hefeng2014/p/17760179.html