jdk1.8新特性Lambda表达式方法引用

前言

  在之前我们接触了JDK1.8引入的新特新lambda表达式没在某种程度上,它可以简化我们的代码,帮助我们快速的编写代码,但在这其中我们之前的编写方式并不是lambda表达式最简洁的方式,而在头屑情况下我们可以使用lambda表达式的方法引用是代码进一步简洁化。

一、方法引用:

  在java中方法引用主要是用来替代lambda表达式进一步简化代码,方法引用符号的写法是两个冒号“::”,其中方法引用的用法有一下几种。

  1、对象名称::成员方法  

    如果一个对象中有一个成员方法,就好就是lambda表达式所需要输出的内容,那么可以使用方法引用,格式:对象名称::方法名称

@FunctionalInterface
public interface FunctionInterface {

    void work(String s);
}

public class Demo01 {
    public void println(String s){
        System.out.println(s);
    }
}

public class DemoTest {

    public static void main(String[] args) {
        Demo01 demo01 = new Demo01();
        test(demo01::println);
    }

    public static void test(FunctionInterface f){
        f.work("shiqingxue");
    }
}

  2、类名称::静态方法

    如果lambda表达式要做的事情,正好就是本类中的一个静态方法内容,那么可以使用方法引用,那么可以使用方法引用,格式:类名称::静态方法

public class Demo02 {
    public static void  hehe(String s){
        System.out.println("人生自是友情池,此恨不关风与月");
    }
}

public class DemoTest {

    public static void main(String[] args) {

        test(Demo02::hehe);
    }

    public static void test(FunctionInterface f){
        f.work("shiqingxue");
    }
}

  3、super::父类方法

    如果lambda表达式要做的事情,正好是父类当中当中的方法内容,那么可以使用方法引用,借助suoer关键字来引用父类中的方法,格式super::父类方法

public class Demo {

    public void notStatic(String s){
        System.out.println("Demo父类普通方法:" + s);
    }

    public static void isStatuic(String s){
        System.out.println("Demo父类静态方法:" + s);
    }
}

public class Demo02 extends  Demo{

    public void DoFunction(String s){
        method(super::notStatic);
    }

    private void method(FunctionInterface s){
        s.work("");
    }
}

public class DemoTest {

    public static void main(String[] args) {
        Demo02 demo02 = new Demo02();
        test(demo02::DoFunction);
    }

    public static void test(FunctionInterface f){
        f.work("shiqingxue");
    }
}

  4、this::本类方法

    如果lambda表达式要做的事情,正好是本类当中的方法内容,那么可以使用方法引用,借助this关键字,格式:this::本类方法

public class Demo02 {

    public void beHappy(String s){
        System.out.println("风吹屁屁凉");
    }

    public void DoFunction(String s){
        method(this::beHappy);
    }

    private void method(FunctionInterface s){
        s.work("");
    }
}

public class DemoTest {

    public static void main(String[] args) {
        Demo02 demo02 = new Demo02();
        test(demo02::DoFunction);
    }

    public static void test(FunctionInterface f){
        f.work("");
    }
}

  5、类名称::new 

    如果lambda表达式要做的事情就是构造方法的内容,那么可以使用构造器引用,格式:类名称::new

@FunctionalInterface
public interface FunctionInterface {
    Object getObject(String s);
}

public class Demo02 {

    private String userName;

    public Demo02(){}

    public Demo02(String s){
        this.userName = s;
    }

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }
}

public class DemoTest {

    public static void main(String[] args) {
        test(Demo02::new);
    }

    public static void test(FunctionInterface f){
        Demo02 hehe = (Demo02) f.getObject("mowen");
        System.out.println(hehe.getUserName());
    }
}

二、lambda的延迟执行

  例如我们系统中需要输出日志,我们可以用日志模拟一下lambda延迟执行,如下代码,例如我们要输出一条日志,如果我们限制只有日志级别为1时才会输出日志,那么上面的代码会造成一定程度上的性能浪费,因为我们在调用日志方法时,首先是执行了拼接字符串的操作,结果在答应日志的判断中不满足条件,日志没有输出,这就在一定程度上造成了资源的浪费。

public class DemoLogger {

    public static void main(String[] args) {
        String string1 = "mowen";
        String string2 = "shiqingxue";
        printlnLogger(2, string1+ string2);
    }

    /**
     * @param level:日志级别
     * @param mesg:日志信息
     */
    public static void printlnLogger(int level, String mesg){
        if(level == 1){
            System.out.println(mesg);
        }
    }
}

  为什么说lambda时延迟执行,我们来看下面一段代码:当我们使用lambda表达式日志级别改成2时,他是不会执行打印日志的操作,同是在拼接字符串前面的打印语句也没有执行,由此可以看出,在我们不满足日志打印条件是字符串拼接并没有执行,和之前的方法形成了鲜明对比,lambda的延迟执行可以提高我们程序的执行效率。

public class DemoLogger {

    public static void main(String[] args) {
        String string1 = "mowen";
        String string2 = "shiqingxue";
        printlnLogger(2,() -> {
            System.out.println("lambda开始执行");
            return string1 + string2;
        });
    }

    /**
     * @param level:日志级别
     * @param f:lambda表达式
     */

    public static void printlnLogger(int level, FunctionInterface f){
        if(level == 1){
            System.out.println(f.logger());
        }
    }
}

原文地址:https://www.cnblogs.com/zouxiangzhongyan/p/11438852.html

时间: 2024-10-05 19:19:50

jdk1.8新特性Lambda表达式方法引用的相关文章

JDK1.8新特性-Lambda 表达式

Lambda 表达式,也可称为闭包. Lambda 允许把函数作为一个方法的参数(函数作为参数传递进方法中). Lambda表达式的好处:1.可以使代码变的更加简洁紧凑. lambda 表达式的语法格式如下: (paramenters) ->  expression  或   (parameters)-> {statements;} lambda表达式有已下几个特征: 1.可选类型声明:不需要声明参数类型,编译器可以统一识别参数值. 2.可选的参数圆括号:一个参数无需定义圆括号,多个参数需要定

jdk1.8新特性 lambda表达式和Stream

一.Lambda 1.lambda : 匿名函数 2.好处:减少打码的冗余,增强匿名函数的可读性 3.语法格式 语法格式一 : 无参数,无返回值 () -> System.out.println("Hello Lambda!"); 语法格式二 : 有一个参数,并且无返回值 (x) -> System.out.println(x) 语法格式三 : 若只有一个参数,小括号可以省略不写 x -> System.out.println(x) 语法格式四 : 有两个以上的参数,

Java 8 新特性 - Lambda表达式(一)

链接 Java8新特性——Lambda表达式(一) 原文地址:https://www.cnblogs.com/tonyq/p/8206131.html

Java核心技术之Java8新特性-Lambda表达式

1 总体说明 Java8新特性概述 函数式接口 Lambda表达式(闭包) 2 Java8新特性概述 Oracle公司于2014年3月发布了Java8正式版,该版本是自JDK5.0以来最具革命性的版本. Java8为Java语言.编译器.类库和JVM带来了大量的新特性.接下来的内容将会详细说明Java8在Java语言方面的新特性以及它们的使用场景. 3 函数式接口 Java8引入的一个核心概念是函数式接口(Functional Interfaces):如果一个接口定义一个唯一的抽象方法,那么这个

java8新特性——Lambda表达式

上文中简单介绍了一下java8得一些新特性,与优点,也是为本次学习java8新特性制定一个学习的方向,后面几篇会根据上文中得新特性一一展开学习.本文就从java8新特性中比较重要的Lambda表达式开始学学习. 一.为什么要使用Lambda表达式 Lambda是一个匿名函数,我们可以baLambda表达式理解为是一段可以传递的代码(将代码像数据一样进行传递).可以写出更简洁,更灵活的代码.作为一种更紧凑得代码风格,使得java得语言表达能力得到提升.Lambda表达式需要函数式接口的支持,接口中

JDK8新特性 Lambda表达式

一.接口的默认方法二.Lambda 表达式三.函数式接口四.方法与构造函数引用五.Lambda 作用域六.访问局部变量七.访问对象字段与静态变量八.访问接口的默认方法九.Date API十.Annotation 注解:支持多重注解 一.接口的默认方法 Java8允许我们给接口添加一个非抽象的方法实现,只需要使用 default关键字即可,这个特征又叫做扩展方法,示例如下: [java] view plain copy public interface Formula { double calcu

Java基础知识总结之1.8新特性lambda表达式

函数式接口 函数式接口(functional interface 也叫功能性接口,其实是同一个东西).简单来说,函数式接口是只包含一个方法的接口.比如Java标准库中的java.lang.Runnable和 java.util.Comparator都是典型的函数式接口.java 8提供 @FunctionalInterface作为注解,这个注解是非必须的,只要接口符合函数式接口的标准(即只包含一个方法的接口),虚拟机会自动判断, 但 最好在接口上使用注解@FunctionalInterface进

JDK8的新特性——Lambda表达式

JDK8已经发布快4年的时间了,现在来谈它的新特性显得略微的有点“不合时宜”.尽管JDK8已不再“新”,但它的重要特性之一——Lambda表达式依然是不被大部分开发者所熟练运用,甚至不被开发者所熟知. 国内的开发环境大家都知道,有各种的老项目,有各种各样的发布风险,让公司以及项目组对新的技术往往望而却步,有公司甚至时至今日还在使用JDK6来进行项目开发,这导致了在很多技术的选择上受到了很大限制,进而不能跟随时代的脚步使得项目甚至公司一步一步走向衰落. 本文简单认识JDK8的重要新特性之一——La

Java8新特性 - Lambda 表达式

 是什么? Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性. Lambda 属于函数式编程思想,允许把函数作为一个方法的参数(函数作为参数传递进方法中). 怎么使用? 使用前提: 必须支持上下文推导,要能够推导出来 Lambda 表达式表示的是哪个接口中的内容. 可以使用接口当做参数,然后传递 Lambda 表达式(常用),也可以将 Lambda 表达式赋值给一个接口类型的变量. Lambda 表达式的省略规则: 小括号中的参数类型可以省略. 如果小括号中只有一个