方法引用与构造器引用
若 Lambda 体中的功能,已经有方法提供了实现,可以使用方法引用(可以将方法引用理解为 Lambda 表达式的另外一种表现形式)
方法引用: 使用操作符 “::” 将方法名和对象或类的名字分隔开来。
# 例如
(x) -> System.out.println(x); 等同于
System.out::println.
方法引用
注意: :
- 方法引用所引用的方法的参数列表与返回值类型,需要与函数式接口中抽象方法的参数列表和返回值类型保持一致!
- 若Lambda 的参数列表的第一个参数,是实例方法的调用者,第二个参数(或无参)是实例方法的参数时,格式: ClassName::MethodName
- 对象::实例方法
# 对象的引用 :: 实例方法名
@Test
public void test2(){
Employee emp = new Employee(101, "张三", 18, 9999.99);
Supplier<String> sup = () -> emp.getName();
System.out.println(sup.get());
System.out.println("----------------------------------");
// 直接使用对象::实例方法来引用
Supplier<String> sup2 = emp::getName;
System.out.println(sup2.get());
}
@Test
public void test1(){
// 标准打印流对象
PrintStream ps = System.out;
Consumer<String> con = (str) -> ps.println(str);
con.accept("Hello World!");
System.out.println("--------------------------------");
// 对象::实例名引用
Consumer<String> con2 = ps::println;
con2.accept("Hello Java8!");
Consumer<String> con3 = System.out::println;
}
- 类::静态方法
# 类名 :: 静态方法名
@Test
public void test4(){
Comparator<Integer> com = (x, y) -> Integer.compare(x, y);
System.out.println("-------------------------------------");
Comparator<Integer> com2 = Integer::compare;
}
@Test
public void test3(){
// (x, y) -> Math.max(x, y) 调用funcation函数的子接口 比较x,y的大小
BiFunction<Double, Double, Double> fun = (x, y) -> Math.max(x, y);
System.out.println(fun.apply(1.5, 22.2));
System.out.println("--------------------------------------------------");
// Math类直接调用静态方法 Math::max 获取最大值
BiFunction<Double, Double, Double> fun2 = Math::max;
System.out.println(fun2.apply(1.2, 1.5));
}
- 类::实例方法
# 类名 :: 实例方法名
@Test
public void test5(){
// BiPredicate断言式接口的子接口
BiPredicate<String, String> bp = (x, y) -> x.equals(y);
System.out.println(bp.test("abcde", "abcde"));
System.out.println("-----------------------------------------");
// 直接使用类名::实例方法名,来调用equals()方法
BiPredicate<String, String> bp2 = String::equals;
System.out.println(bp2.test("abc", "abc"));
System.out.println("-----------------------------------------");
Function<Employee, String> fun = (e) -> e.show();
System.out.println(fun.apply(new Employee()));
System.out.println("-----------------------------------------");
// 创建函数调用show方法 直接调用Employee::show类中的show方法
Function<Employee, String> fun2 = Employee::show;
System.out.println(fun2.apply(new Employee()));
}
构造器引用
构造器引用 :构造器的参数列表,需要与函数式接口中参数列表保持一致!
类名::new 方式调用构造器
# 构造器引用
@Test
public void test7(){
// 调用一个参数的构造器
Function<String, Employee> fun = Employee::new;
// 两个参数的构造器,参数类型为String, Integer,构建对象为Employee
BiFunction<String, Integer, Employee> fun2 = Employee::new;
}
@Test
public void test6(){
// Supplier返回对象 () -> new Employee() 新建一个对象
Supplier<Employee> sup = () -> new Employee();
System.out.println(sup.get());
System.out.println("------------------------------------");
// 类名::new 方式调用构造器 空参构造器
Supplier<Employee> sup2 = Employee::new;
System.out.println(sup2.get());
}
数组引用
类型[] :: new
# 数组引用
@Test
public void test8(){
// 构建创建String[] 数组的函数
Function<Integer, String[]> fun = (args) -> new String[args];
// 设置数组的大小
String[] strs = fun.apply(10);
System.out.println(strs.length);
System.out.println("--------------------------");
// 构建创建String[] 数组的函数
Function<Integer, Employee[]> fun2 = Employee[] :: new;
// 数组长度设置为20
Employee[] emps = fun2.apply(20);
System.out.println(emps.length);
}