其实Java中的普通方法是有隐藏参数的,这个参数就是我们熟悉的this,所有的普通方法都是一样的 比如下面的eat方法
class F1{
//这里的方法签名是String eat()
String eat() {
System.out.println(this);
return "hello";
}
}
但是在JVM的角度上看,实际调用实例方法需要有一个this对象,你可以像下面这样去想
String eat(F1 f1) //使用f1.eat调用方法
(但实际方法签名不是这样的,签名还是以我们看到的为准String eat()
),只是JVM需要拿到实例去调用方法,这一切都是隐藏的
其实想想也知道,不然我们为什么能在一个没有参数的方法中去打印this呢?这个this是从哪里来的?实际上this是作为普通方法的第一个参数被传入的,如果一个普通方法有多个参数,那么this是排在第一位(只是被隐藏了),后续参数按照代码顺推的,所以我们有时可以看到方法引用没有严格按照方法签名去匹配,就是这个原因,就像下面这样
public class Test {
public static void main(String[] args) {
// 实际上这里将eat方法赋值给Apple的时候,
// 你可以将eat的方法签名看作 String eat(F1 f1)
//(只是可以这样去想,实际签名还是String eat())
// 这里正好Apple的泛型就是F1,所以可以完美匹配
Apple<F1> apple = F1::eat;
// 在调用的时候你需要一个F1的实例,这样Java将会使用该实例去调用eat方法
System.out.println(apple.apply(new F1()));
}
}
class F1{
//这里的方法签名是String eat()
String eat() {
System.out.println(this);
return "在吃苹果";
}
}
@FunctionalInterface
interface Apple<T>{
String apply(T t);
}