Tengo el siguiente código que da como resultado la producción esperada. Podría alguien explicar lo que está sucediendo detrás de las cortinas? No entiendo cómo lo hace el compilador / JVM sabe que se necesita para invocar tienda (String str) en el Storer objeto o cómo se define el doSomething (s Storer, cadena str) aplicación.
Storer.java
public class Storer {
private List<String> storer = new ArrayList<>();
public void store(String str) {
storer.add(str);
}
@Override
public String toString() {
return "Storer [storer=" + storer + "]";
}
}
MyInterface.java
@FunctionalInterface
public interface MyInterface {
public abstract void doSomething(Storer s, String str);
}
Executor.java
public class Executor {
public void doStore(Storer storer, String s, MyInterface p) {
p.doSomething(storer, s);
}
}
TestFunctionalInterfaces.java
public class TestFunctionalInterfaces {
public static void main(String[] args) {
Storer storer = new Storer();
Executor test = new Executor();
test.doStore(storer, "I've got added", Storer::store);
System.out.println(storer);
}
}
Una salida es:
Storer [storer=[I've got added]]
Gracias por adelantado.
El método de referencia Store::storer
es equivalente a la lambda (s, str) -> s.store(str)
. En general, dada una interfaz funcional que espera que args a1, a2, a3, ..., a la referencia del método de este tipo es equivalente a un lambda que llama a1.namedMethod (a2, a3, ...). Ver esta respuesta .