ricky java_恕我直言你可能真的不会java第8篇-函数式接口

一、函数式接口是什么?

所谓的函数式接口,实际上就是接口里面只能有一个抽象方法的接口。我们上一节用到的Comparator接口就是一个典型的函数式接口,它只有一个抽象方法compare。

48e86a15c761b9347690839d3f0cfc16.png

只有一个抽象方法?那上图中的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,

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() {

@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);

欢迎关注我的博客,里面有很多精品合集

本文转载注明出处(必须带连接,不能只转文字):字母哥博客。

觉得对您有帮助的话,帮我点赞、分享!您的支持是我不竭的创作动力! 。另外,笔者最近一段时间输出了如下的精品内容,期待您的关注。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值