JDK8--05:方法引用和构造器引用
在上一篇文章中,说过JDK8中内置的函数时接口,为了方便使用,JDK8还提供了方法引用和构造器引用,来简化lambda的写法
1、方法引用
方法引用说明:lambda表达式中的方法已经在其他方法中已经有实现,可以直接使用双冒号进行方法引用,引用的前提是使用的出入参和引用方法的出入参必须一致
对象引用有三种写法:
对象::实例方法名
类::静态方法名
类::实例方法名
再写代码示例前,先新增一个Student的内部类,以供后面演示使用
class Student{
private String name = "lcl";
private Integer age = ;
public String getName() {
return name;
}
public Integer getAge() {
return age;
}
}
(1)首先说第一种,对象::实例方法名
@Test
public void test1(){
//方法引用,lambda表达式中的方法已经在其他方法中已经有实现,可以直接使用双冒号进行方法引用,引用的前提是使用的出入参和引用方法的出入参必须一致
//对象::实例方法名
PrintStream ps = System.out;
Consumer<String> consumer = (x)->ps.println(x);
consumer.accept("000000000000000000000"); PrintStream ps1 = System.out;
Consumer<String> consumer1 = ps1::println;
consumer1.accept("111111111111111111111"); Consumer<String> consumer2 = System.out::println;
consumer2.accept("2222222222222222222222"); }
上述代码中,第一种实现,就是使用原来说的lambda的写法,因为在PrintStream对象中,已经有println方法的实现,并且println方法的出入参(入参可以是String,出参为空)符合消费型接口Consumer的出入参,因此可以直接使用方法引用返回Consumer。
测试结果:

同样,我们可以使用自己创建的类,只要方法的出入参符合函数时接口的出入参即可,这里拿上面创建的Student对象的getName和getAge方法演示
@Test
public void test4(){ Student student = new Student();
Supplier<String> supplier = ()-> student.getName();
log.info("Supplier===================={}",supplier.get()); Supplier<Integer> supplier1 = student::getAge;
Integer age = supplier1.get();
log.info("Supplier===================={}",age);
}
由于getAge和getName方法的出入参都符合Suppiler的出入参(无入参,有出参),因此可以使用Suppiler进行处理
测试结果:

(2)然后再说第二种实现方式 类::静态方法名
@Test
public void test5(){
//类::静态方法名
Comparator<Integer> comparator = Integer::compare;
log.info("=================={}",comparator.compare(,));
}
测试结果:

(3)最后说第三种实现方式 类::实例方法名
使用该种方法,有条件限制:第一个入参是调用该方法的调用者,第二个参数是方法引用的入参时,可以使用类的实例方法调用
示例代码:
@Test
public void test6(){
//类::实例方法名
//条件限制:第一个入参是调用该方法的调用者,第二个参数是方法引用的入参时,可以使用类的实例方法调用
BiPredicate<String, String> biPredicate = (x, y) -> x.equals(y);
log.info("=========================={}",biPredicate.test("","")); BiPredicate<String, String> biPredicate1 = String::equals;
log.info("=========================={}",biPredicate.test("","")); }
测试结果:

2、构造器引用
首先为Student创建三个构造器,分别是无参构造器,一个参数的构造器和两个参数的构造器
class Student{
private String name = "lcl";
private Integer age = ;
public String getName() {
return name;
}
public Integer getAge() {
return age;
}
public Student(String name){
this.name = name;
age = ;
}
public Student(String name, Integer age){
this.name = name;
this.age = age;
}
public Student(){
this.name = "lcl";
this.age = ;
}
}
然后,演示构造器引用的使用方法:
@Test
public void test2(){
Supplier<Student> supplier = ()->new Student();
log.info("======================{}",JSON.toJSONString(supplier.get()));
Supplier<Student> supplier1 = Student::new;
log.info("======================{}",JSON.toJSONString(supplier1.get())); Function<String, Student> function = (x)->new Student(x);
log.info("===================={}",JSON.toJSONString(function.apply("lcl"))); Function<String, Student> function1 = Student::new;
log.info("===================={}",JSON.toJSONString(function1.apply("mm")));
BiFunction<String , Integer ,Student> function2 = Student::new;
log.info("===================={}",JSON.toJSONString(function2.apply("xxx",)));
}
代码分为三组,分别演示对于无参构造器,一个参数的构造器和两个参数的构造器的引用,可以发现,引用的写法一摸一样,具体调用的是哪个构造器,则根据函数式接口的参数而定。
测试结果:

4、除了方法引用和构造器引用外,JDK8还提供了数组引用,其实也相当于是构造器引用
代码示例:
@Test
public void test3(){
//数组引用
Function<Integer,String[]> function = (x)-> new String[x];
log.info("===================={}",function.apply().length); Function<Integer,String[]> function1 = String[]::new;
log.info("===================={}",function1.apply().length);
}
测试结果:

JDK8--05:方法引用和构造器引用的更多相关文章
- java8新特性——方法引用与构造器引用
上篇文章简单学习了java8内置得4大核心函数式接口,这类接口可以解决我们遇到得大多数得业务场景得问题.今天来简单学习一下方法引用与构造器引用. 一.方法引用 方法引用:若lambda 体中得内容已经 ...
- JDK8新特性04 方法引用与构造器引用
import java.io.PrintStream; import java.util.Comparator; import java.util.function.*; /** * 一.方法引用 * ...
- JAVA 8 主要新特性 ----------------(五)Lambda方法引用与构造器引用
一.Lambda方法引用 当要传递给Lambda体的操作,已经有实现的方法了,可以使用方法引用!(实现抽象方法的参数列表,必须与方法引用方法的参数列表保持一致!) 方法引用: 使用操作符 “::” 将 ...
- Java8新特性 -- Lambda 方法引用和构造器引用
一. 方法引用: 若Lambda体中的内容有方法已经实现了,我们可以使用“方法引用” 要求 方法的参数和返回值类型 和 函数式接口中的参数类型和返回值类型保持一致. 主要有三种语法格式: 对象 :: ...
- Java8 方法引用与构造器引用,数组引用
package java_8; import org.junit.Test; import java.io.PrintStream; import java.util.Comparator; impo ...
- Java8新特性 - 方法引用与构造器引用
方法引用 若Lambda体中的内容有方法已经实现了,我们可以使用"方法应用",可以理解为方法引用是Lambda表达式的另外一种表现形式. 使用操作符"::"将方 ...
- Java8新特性(三)之方法引用和构造器引用
1.使用场景 当要传递给Lambda体的操作,已经存在实现的方法了,就可以使用方法引用.(抽象方法的参数列表 必须与方法引用方法的参数列表保持一致) 2. 语法 使用操作符[::]将方法名和对象或类 ...
- 方法引用(Method reference)和构造器引用(construct reference)
Java 8 允许你使用 :: 关键字来传递方法或者构造函数引用 方法引用语法格式有以下三种: objectName::instanceMethod ClassName::staticMethod C ...
- Lambda 方法引用 构造器引用 数组引用
一.方法引用 注意: 1.Lambda 体中调用方法的参数列表与返回值类型,要与函数式接口中的抽象方法的函数列表和返回值保持一致!2.若Lambda 参数列表中的第一个参数是实例方法的调用者,而第二个 ...
随机推荐
- Alpha冲刺 —— 5.8
这个作业属于哪个课程 软件工程 这个作业要求在哪里 团队作业第五次--Alpha冲刺 这个作业的目标 Alpha冲刺 作业正文 正文 github链接 项目地址 其他参考文献 无 一.会议内容 1.展 ...
- [C#.NET拾遗补漏]01:字符串操作
字符串操作在任意编程语言的日常编程中都随处可见,今天来汇总一下 C# 中关于字符串的一些你可能遗忘或遗漏的知识点. 逐字字符串 在普通字符串中,反斜杠字符是转义字符.而在逐字字符串(Verbatim ...
- DDD之3实体和值对象
图中是一个别墅的模型,代表实体,可以真实的看得到.那么在DDD设计方法论中,实体和值对象是什么呢? 背景 实体和值对象是领域模型中的领域对象,是组成领域模型的基础单元,一起实现实体最基本的核心领域逻辑 ...
- Java 蓝桥杯 算法训练 貌似化学
** 貌似化学 ** 问题描述 现在有a,b,c三种原料,如果他们按x:y:z混合,就能产生一种神奇的物品d. 当然不一定只产生一份d,但a,b,c的最简比一定是x:y:z 现在给你3种可供选择的物品 ...
- Java实现 蓝桥杯VIP 算法提高 连接乘积
算法提高 连接乘积 时间限制:1.0s 内存限制:256.0MB 问题描述 192这个数很厉害,用它分别乘以1.2.3,会得到: 192 x 1 = 192 192 x 2 = 384 192 x 3 ...
- Java实现 蓝桥杯 历届试题 剪格子
问题描述 如下图所示,3 x 3 的格子中填写了一些整数. +--*--+--+ |10* 1|52| +--****--+ |20|30* 1| *******--+ | 1| 2| 3| +--+ ...
- Java与Swift对比
本文链接:http://blog.csdn.net/msyqmsyq/article/details/53538159 从Java到Swift还是比较简单的,相比Object-C,Swift和Java ...
- 【大厂面试06期】谈一谈你对Redis持久化的理解?
Redis持久化是面试中经常会问到的问题,这里主要通过对以下几个问题进行分析,帮助大家了解Redis持久化的实现原理. 1.Redis持久化是什么? 2.Redis持久化有哪些策略?各自的实现原理是怎 ...
- 纯CSS如何实现状态圆点
.circle { display: inline-block; width: 12px; height: 12px; } .circle:after { content: ''; margin: 3 ...
- Jenkins入门教程(一):Windos下Jenkins的安装教程
Jenkins的安装教程 Jenkins安装前的准备 1.安装jenkins前首先确保你的电脑已经安装了JDK,由于jenkins是基于java开发的 JDK下载地址 2.下载jenkins的安装包 ...