interfaz personalizada funcional como argumento de un método

Anton:

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.

Mathias:

El método de referencia Store::storeres 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 .

Supongo que te gusta

Origin http://43.154.161.224:23101/article/api/json?id=204322&siteId=1
Recomendado
Clasificación