lambda表达式的诞生是为了解决java创建匿名内部类代码冗余的问题。例子如下:
public class新疆禾木 lambda { public static void main(string[] args) { gog gog = new gog() { @override public void say() { system.out.println("wow"); } }; gog.say(); }}interface gog { void say();}
这里我们想实现接口的say方法,由于实例化接口会创建匿名内部类,需要将接口中的所有方法实现。为了实现一个简单的方法冗余了许多代码出来。那么如果用lambda 表达式去简化呢。例子如下:
public class lambda { public static void main(string[] args) { //lambda表达式的写法即: ()-> {函数实现} 当函数实现只有一行代码时,可以省略大括号 如下所示: gog gog = () -> system.out.println("wow"); gog.say(); }}interface gog { void say();}
只包含一个抽象方法的接口称为函数式接口。而也只有函数式接口可以利伏尔加河地图用lambda 表达式进行简化。其实原因很简单。如果接口中有多个方法,lambda表达式将无法明确调用的是那个函数。
而根据抽象函数的返回值与参数列表,函数式接口可以简单的分为以下4种类型:
//1.供给型接口:interface supplier<t>没有参数,有返回值interface supplier { string say();}//2.消费型接口:interface consumer<t>只有输入,没有返回值interface consumer{ void say(string name);}//3.断定型接口:interface predicate<t>传入参数t,返回值类焰色反应型为boolean类型interface predicate{ boolean say(string name);}//4.函数型接口:interface function<t,r>传入参数类型为t,返回值类型为rinterface function{ string say(int age);}
举几个我们身边中常用到的lambda函数
public class mythread { public static void main(string[] args) { new thread(() -> { system.out.println("创建线程"); }).start(); }}
如上代码大家必然很熟悉,一个很简单的创却字能组什么词建线程的方法。我们进入thread对应的构造函数看看。
可以看到,我们调用的构造函数的入参是runnable接口,而我们在看看我们创建的时候,明明使用的是lambda 表达式,那么可以断定,runnable接口必定是一个函数式接口
注意!!由于jdk8之后,接口中的函数可以拥有默认实现,这种拥有默认实现的方法,并不会影响这个接口成为函数式接口。例子如下:
public class lambda { public static void main(string[] args) { supplier supplier = ()-> "wow"; system.out.println(supplier.say()); }}interface supplier { string say(); default string name(){ return ""; }}
supplier 接口中有两个函数,但是依然可以成为函数式接口,利用lambda 表达式进行简化。
到此这篇关于javalambda表达式与函数式接口详解的文章就介绍到这了,更多相关javalambda表达式与函数式接口内容请搜索www.887551评价方案.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-05 00:15:02,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/34dc660a88b484aeded292c3b6fa7a55.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:JAVALambda表达式与函数式接口详解.doc
本文 PDF 下载地址:JAVALambda表达式与函数式接口详解.pdf
留言与评论(共有 0 条评论) |