Java的λ表达(lambda)

λ表达的基本目的

回调Java8的λ表达式 说明了Java8的λ表达式的基本用途:完毕了回调的原意——代码的參数化。

回调:能够简单地说,假设你的方法须要override底层或JDK的某个类的方法,并且你从来没有自己调用过该方法,则该方法(有时候,也指被改写的方法)就是回调。比如

  • Applet定义的init()、start()、stop()和destroy();
  • 图形绘制方法paint(Graphics)、update(Graphics)和重载的repaint()。
  • java.lang.Runnable的run();
  • GUI中ActionListener的actionPerformed(ActionEvent e)...

在Java8之前,回调的代码通常由匿名类提供,例如以下代码(完整代码见回调与Java8的λ表达式 )

        s.register(new IClient(){
             @Override public void callback(int i){
                 System.out.println("==" + i + "0%");
             }
        });

如今则能够:

        IClient listener1=(i)->{System.out.println("+" + i + "0%");};
        s.register(listener1);
        s.register((i)->{System.out.println("++" + i + "0%");});

显然,使用λ表达式提供回调代码较匿名类简洁,较Client implements IClient简洁得很多其它。

λ表达式有三部分组成:(參数列表),箭头->,{一个代码块}

由于IClient是仅有一个抽象方法的接口,既然唯一的抽象方法是

public void callback(int i);

那么,而编译器将赋值给IClient类型变量如listener1的“某λ表达式”,识别为给那个唯一的抽象方法提供方法体的匿名实现类的引用。

从代码输入的角度。λ表达式就能够尽可能的简单。

  • IClient listener1= (int i)->{System.out.println("+" + i + "0%");};

    //IClient的唯一的抽象方法的方法名不须要了,肯定为callback提供方法体。也不能要方法名。λ表达式的三部分,容不下方法名。

  • listener1=(i)->{/**/};  

    //能够省略i的类型,编译器从唯一的抽象方法的形參列表中能够推导类型

  • listener1=i->{};

    //仅仅有单一的形參的时候,能够省略λ表达式的形參括号

其它情况,你能够依照写程序最少的原则。自己试一试。

比如

  1. (參数列表)部分:有多个參数时,能够(int
    i。int j)、(i,j);一个參数,(i)、i->。无參数。()->

    如int getX()。其λ表达式为 ()->{return 0;} ()->0;

    //yqj2065还想省略形參括号,如同“->0”。

  2. {一个代码块}部分:多个语句时,方法体;void方法,方法体;有返回值的单一语句。如int
    add(int i。int j)。其λ表达式为(i,j)->{return
    i+j;} 或 (i,j)->i+j;

函数接口

为什么可以写出

  • IClient listener1=某λ表达式;
  • s.register(某λ表达式);

由于IClient是仅有一个抽象方法的接口——函数(型)接口(functional
interface)

  1. IClient listener1=某λ表达式;

    编译器解读为 某λ表达式 为IClient的仅有抽象方法提供代码。

    尽管IClient“是一个”Object,能够

    Object obj= listener1;

    可是。

    Object obj= 某λ表达式;

    感觉上就不太靠谱,“某λ表达式”是为谁的仅有抽象方法提供代码呢?so。

    Object obj= (IClient)某λ表达式;//ok

  2. s.register(某λ表达式);

    由于依照register(IClient listener),编译器知道 某λ表达式 为IClient的仅有抽象方法提供代码。

函数接口仅仅可以有一个抽象方法。

如果IClient继承Runnable。又想作为函数接口@FunctionalInterface,就得给继承过来的run()提供方法体(这里给一个空方法体凑数)。

package Lower;
/**
 * @author yqj2065
 */
@FunctionalInterface
public interface IClient extends Runnable{
    int add(int i,int j);
     @Override  default public  void run(){};
}

函数接口(一般地,普通接口)中使用
defaultkeyword,能够加入具有实现的方法,这个玩意就是Java接口的默认方法

在函数接口中出现默认方法,好像有点理由。一般接口中使用默认方法。參考纠结的默认方法

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveXFqMjA2NQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" style="border:none; max-width:100%">

时间: 2024-08-07 00:14:15

Java的λ表达(lambda)的相关文章

Java正则表达中Greedy Reluctant Possessive 的区别

上一篇文章<编程思想之正则表达式 >中讲了正则表达式的原理.使用方法和常见的正则表达式总结,本文将进一步探讨Java正则表达中Greedy.Reluctant.Possessive三种策略的区别. 从Java的官方文档http://docs.oracle.com/javase/7/docs/api/java/util/regex/Pattern.html中我们可以看到,正则表达式表示数量词的符号有三套,分别是Greedy(贪婪的).Reluctant(勉强的)和Possessive(独占的).

java 8 中lambda表达式学习

转自 http://blog.csdn.net/renfufei/article/details/24600507 http://www.jdon.com/idea/java/10-example-of-lambda-expressions-in-java8.html Lambda表达式的语法基本语法:(parameters) -> expression或(parameters) ->{ statements; } 下面是Java lambda表达式的简单例子: // 1. 不需要参数,返回值

Java 8之Lambda

公司内部的一些新项目相继采用了Java 8,这才有了动力好好的研究一下Java 8这个传说中的大杀器.Java 8文档里面提到的第一个改进就是Lambda,就从它入手好了.社区好多大神都已经研究几年了,拜一下.有不准确的地方,望指正. 为什么要Lambda 把Java代码写得更简洁一点,更直白来说,就是写出来的代码篇幅更短.那么简单?核心来说,是的,不过可能额外带来一些好处.理论上来说,Lambda不是必需品,有了写的代码更优雅简练.Java最被诟病的问题之一就是代码量大(很多是无用的,只是语法

java 8之Lambda Expressions 解说

java 8之Lambda Expressions 解说 java 8 新增Lambda Expressions 的目的:为了使代码简洁易读和消除过多的冗余代码(尽量让编译器做代码转换工作,也可以认为是语法糖之类的作用). 使用过c.c++语言的人,都记得,他们的函数参数可以是函数指针即代码片段(某些行为),而在java语言中,要想使得函数为参数,必须把函数封装成对象,以对象传参才可以.而 java 8 新增Lambda Expressions 使得这一现状得到缓解(函数式变成.闭包之类的概念都

Java 终于有 Lambda 表达式啦~Java 8 语言变化&mdash;&mdash;Lambda 表达式和接口类更改【转载】

原文地址 en cn 下载 Demo Java? 8 包含一些重要的新的语言功能,为您提供了构建程序的更简单方式.Lambda 表达式 为内联代码块定义一种新语法,其灵活性与匿名内部类一样,但样板文件要少得多.接口更改使得接口可以添加到现有接口中,同时又不会破坏与现有代码的兼容性.本文将了解这些更改是如何协同工作的. Java 8 的最大变化在于添加了对 lambda 表达式 的支持.Lambda 表达式是可按引用传递的代码块.类似于一些其他编程语言中的闭包:它们是实现某项功能的代码,可接受一个

在Android中使用Java 8的lambda表达式

译自http://www.coshx.com/blog/2015/03/23/use-java-8s-lambda-functions-in-android/ 在Android中使用Java 8的lambda表达式 作为一名Java开发者,或许你时常因为信息的封闭性而产生许多的困扰.幸运的是:Java's 8th version introduced lambda functions给我们带来了好消息:然而,这咩有什么卵用,在android上面,我们仍旧只能使用Java7. 那么现在情况如何?哈

[Java 8] 使用Lambda表达式进行设计

使用Lambda表达式进行设计 在前面的几篇文章中,我们已经见识到了Lambda表达式是如何让代码变的更加紧凑和简洁的. 这一篇文章主要会介绍Lambda表达式如何改变程序的设计,如何让程序变的更加轻量级和简洁.如何让接口的使用变得更加流畅和直观. 使用Lambda表达式来实现策略模式 假设现在有一个Asset类型是这样的: public class Asset { public enum AssetType { BOND, STOCK }; private final AssetType ty

[Java 8] (9) Lambda表达式对递归的优化(下) - 使用备忘录模式(Memoization Pattern) .

使用备忘录模式(Memoization Pattern)提高性能 这个模式说白了,就是将需要进行大量计算的结果缓存起来,然后在下次需要的时候直接取得就好了.因此,底层只需要使用一个Map就够了. 但是需要注意的是,只有一组参数对应得到的是同一个值时,该模式才有用武之地. 在很多算法中,典型的比如分治法,动态规划(Dynamic Programming)等算法中,这个模式运用的十分广泛. 以动态规划来说,动态规划在求最优解的过程中,会将原有任务分解成若干个子任务,而这些子任务势必还会将自身分解成更

【转】Java 8十个lambda表达式案例

1. 实现Runnable线程案例 使用() -> {} 替代匿名类: //Before Java 8: new Thread(new Runnable() { @Override public void run() { System.out.println("Before Java8 "); } }).start(); //Java 8 way: new Thread( () -> System.out.println("In Java8!") ).s