一、函数式接口是什么?
所谓的函数式接口,实际上就是接口内里只能有一个抽象方式的接口。我们上一节用到的Comparator接口就是一个典型的函数式接口,它只有一个抽象方式compare。
只有一个抽象方式?那上图中的equals方式不是也没有函数体么?不急,和我一起往下看!
二、函数式接口的特点
- 接口有且仅有一个抽象方式,如上图的抽象方式compare
- 允许界说静态非抽象方式
- 允许界说默认defalut非抽象方式(default方式也是java8才有的,见下文)
- 允许java.lang.Object中的public方式,如上图的方式equals。
- FunctionInterface注解不是必须的,若是一个接口相符”函数式接口”界说,那么加不加该注解都没有影响。加上该注解能够更好地让编译器举行检查。若是编写的不是函数式接口,然则加上了@FunctionInterface,那么编译器会报错
甚至可以说:函数式接口是专门为lambda表达式准备的,lambda表达式是只实现接口中唯一的抽象方式的匿名实现类。
三、default关键字
顺便讲一下default关键字,在java8之前
- 接口是不能有方式的实现,所有方式全都是抽象方式
- 实现接口就必须实现接口内里的所有方式
这就导致一个问题:当一个接口有许多的实现类的时刻,修改这个接口就变成了一个异常贫苦的事,需要修改这个接口的所有实现类。
这个问题困扰了java工程师许久,不外在java8中这个问题获得了解决,没错就是default方式
- default方式可以有自己的默认实现,即有方式体。
- 接口实现类可以不去实现default方式,而且可以使用default方式。
四、JDK中的函数式接口举例
java.lang.Runnable,
谈反应式编程在服务端中的应用,数据库操作优化,提速 Upsert
java.util.Comparator,
java.util.concurrent.Callable
java.util.function包下的接口,如Consumer、Predicate、Supplier等
五、自界说Comparator排序
我们自界说一个排序器,实现compare函数(函数式接口Comparator唯一的抽象方式)。返回0示意元素相等,-1示意前一个元素小于后一个元素,1示意前一个元素大于后一个元素。这个规则和java 8之前没什么区别。
下面代码用自界说接口实现类的的方式实现:凭据岁数的倒序排序!
employees.sort(new Comparator<Employee>() {
@Override
public int compare(Employee em1, Employee em2) {
if(em1.getAge() == em2.getAge()){
return 0;
}
return em1.getAge() - em2.getAge() > 0 ? -1:1;
}
});
employees.forEach(System.out::println);
最终的打印效果如下,凭据岁数的自界说规则举行排序。
Employee(id=8, age=79, gender=M, firstName=Alex, lastName=Gussin)
Employee(id=7, age=68, gender=F, firstName=Melissa, lastName=Roy)
Employee(id=10, age=45, gender=M, firstName=Naveen, lastName=Jain)
Employee(id=3, age=43, gender=M, firstName=Ricky, lastName=Martin)
Employee(id=4, age=26, gender=M, firstName=Jon, lastName=Lowman)
Employee(id=1, age=23, gender=M, firstName=Rick, lastName=Beethovan)
Employee(id=5, age=19, gender=F, firstName=Cristine, lastName=Maria)
Employee(id=9, age=15, gender=F, firstName=Neetu, lastName=Singh)
Employee(id=6, age=15, gender=M, firstName=David, lastName=Feezor)
Employee(id=2, age=13, gender=F, firstName=Martina, lastName=Hengis)
这段代码若是以lambda表达式简写。箭头左侧是参数,右侧是函数体,参数类型和返回值凭据上下文自动判断。如下:
employees.sort((em1,em2) -> {
if(em1.getAge() == em2.getAge()){
return 0;
}
return em1.getAge() - em2.getAge() > 0 ? -1:1;
});
employees.forEach(System.out::println);
迎接关注我的博客,内里有许多精品合集
- 本文转载注明出处(必须带毗邻,不能只转文字):字母哥博客。
以为对您有辅助的话,帮我点赞、分享!您的支持是我不竭的创作动力! 。另外,笔者最近一段时间输出了如下的精品内容,期待您的关注。
- 《手摸手教你学Spring Boot2.0》
- 《Spring Security-JWT-OAuth2一本通》
- 《实战前后端星散RBAC权限治理系统》
- 《实战SpringCloud微服务从青铜到王者》
- 《VUE深入浅出系列》
原创文章,作者:28x29新闻网,如若转载,请注明出处:https://www.28x29.com/archives/18826.html