Java8新特性_方法引用与构造器引用

3-方法引用与构造器引用
方法引用

当要传递给Lambda体的操作,已经有实现的方法了,可以使用方法引用!
(实现抽象方法的参数列表,必须与方法引用方法的参数列表保持一致!)
方法引用:使用操作符 “::” 将方法名和对象或类的名字分隔开来。
如下三种主要使用情况:

对象::实例方法
类::静态方法
类::实例方法

注意:当需要引用方法的第一个参数是调用对象,并且第二个参数是需要引用方法的第二个参数(或无参数)时:ClassName::methodName

构造器引用

格式: ClassName::new
与函数式接口相结合,自动与函数式接口中方法兼容。
可以把构造器引用赋值给定义的方法,与构造器参数列表要与接口中抽象方法的参数列表一致!

数组引用

格式: type[] :: new

package day01.com.lm.java8;

import org.junit.Test;

import java.io.PrintStream;
import java.util.Comparator;
import java.util.function.*;

/**
 * 一、方法引用:若Lambda体中的内容有方法已经实现了,我们可以使用“方法引用”
 *          (可以理解方法引用是Lambda表达式的另外一种表现形式)
 *
 * 主要有三种语法格式:
 *
 * 对象::实例方法名
 *
 * 类::静态方法名
 *
 * 类::实例方法名
 *
 * 注意:
 *  ①Lambda体中调用方法的参数和返回值类型,要与函数式接口中抽象方法的函数列表和返回值保持一致!
 *  ②若Lambda参数列表中的第一参数是实例方法的调用者,而第二个参数是实例方法的参数时,可以使用 ClassName :: method
 *
 * 二、构造器引用:
 *
 *  格式:
 *
 *  ClassName::new
 *
 *  注意:需要调用的构造器的参数列表要与函数式接口中抽象方法的参数列表一致
 *
 * 三、数组引用
 *
 *  Type::new
 */
public class TestMethodRef {
    
    

    //对象::实例方法名
    @Test
    public void test1() {
    
    
        String abcdef = "abcdef";
        PrintStream ps1 = System.out;
        Consumer<String> con = (x) -> ps1.println(x);
        con.accept(abcdef);

        PrintStream ps = System.out;
        Consumer<String> con1 = ps::println;
        con1.accept(abcdef);

        Consumer<String> con2 = System.out::println;
        con2.accept(abcdef);
    }

    @Test
    public void test2() {
    
    
        Employee emp = new Employee();
        Supplier<String> sup = () -> emp.getName();
        String str = sup.get();
        System.out.println(str);

        Supplier<Integer> sup2 = emp::getAge;
        Integer num = sup2.get();
        System.out.println(num);
    }

    //类::静态方法名
    @Test
    public void test3() {
    
    
        Comparator<Integer> com = (x, y) -> Integer.compare(x, y);
        System.out.println(com.compare(6, 7));

        Comparator<Integer> com1 = Integer::compare;
        System.out.println(com1.compare(6, 7));
    }

    //类::实例方法名
    @Test
    public void test4() {
    
    
        BiPredicate<String, String> bp = (x, y) -> x.equals(y);
        System.out.println(bp.test("abc", "abc"));

        BiPredicate<String, String> bp2 = String::equals;
        System.out.println(bp2.test("abc", "abc"));
        System.out.println(bp2.test("abc", null));
//        System.out.println(bp2.test(null, "abc"));//空指针异常
    }

    //构造器引用
    @Test
    public void test5() {
    
    
        Supplier<Employee> sup = () -> new Employee();

        //构造器引用方式
        Supplier<Employee> sup2 = Employee::new;
        Employee emp = sup2.get();
        System.out.println(emp);
    }

    @Test
    public void test6() {
    
    
        Function<Integer, Employee> fun = (x) -> new Employee(x);

        Function<Integer, Employee> fun2 = Employee::new;
        Employee emp = fun2.apply(101);
        System.out.println(emp);

//        BiFunction<Integer, Integer, Employee> bf = Employee::new;//Employee没有传2个参数的构造器,所以不可引用
    }

    //数组引用
    @Test
    public void test7() {
    
    
        Function<Integer, String[]> fun = (x) -> new String[x];
        String[] strs = fun.apply(10);
        System.out.println(strs.length);

        Function<Integer, String[]> fun2 = String[]::new;
        String[] strs2 = fun2.apply(20);
        System.out.println(strs2.length);
    }
}

猜你喜欢

转载自blog.csdn.net/m0_51945027/article/details/119962267