Java中的Func编程。 Method-ref与功能应用签名不匹配但成功运行

时间:2015-08-11 09:20:35

标签: java functional-programming java-8 method-reference

我目前正在阅读Functional Programming in Java by Venkat Subramaniam,到目前为止,这是一本很棒的阅读材料。

然而,有一个特殊的例子让我感到困惑。在下面的代码示例中,有一个名为setFilters(final Function<Color,Color>... filters)的方法。

这需要一个实现Function接口的列表。在代码中,使用方法引用调用setFilters ... camera.setFilters(Color::lighter, Color::darker);

这很令人困惑,因为Color类没有实现Function接口,也没有匹配R apply(T t);签名的方法。

我错过了一些明显的东西吗?有人可以解释如何将Color::darker等传递给期望Function<Color,Color>

的参数

以下是完整的代码示例:

package designing.fpij;

import com.sun.scenario.effect.impl.sw.sse.SSEBlend_SRC_OUTPeer;

import java.util.stream.Stream;
import java.util.function.Function;
import java.awt.Color;
import java.util.function.Consumer;

@SuppressWarnings("unchecked")
public class Camera {  
  private Function<Color, Color> filter;


  public Color capture(final Color inputColor) {
    final Color processedColor = filter.apply(inputColor);
    return processedColor;
  }

  public void setFilters(final Function<Color, Color>... filters) {
    filter =
            Stream.of(filters).
                    reduce((after, before) -> filter.compose(before)).orElse(color -> color);
  }
  public Camera() {
    setFilters();
  }

  public static void main(final String[] args) {
    final Camera camera = new Camera();
    final Consumer<String> printCaptured = (filterInfo) ->
            System.out.println(String.format("with %s: %s", filterInfo, camera.capture(new Color(200, 100, 150))));

    System.out.println("//" + "START:NOFILTER_OUTPUT");
    printCaptured.accept("no filter");
    System.out.println("//" + "END:NOFILTER_OUTPUT");

    System.out.println("//" + "START:BOTH_OUTPUT");
    camera.setFilters(Color::brighter, Color::darker);
    printCaptured.accept("brighter & darker filter");
    System.out.println("//" + "END:BOTH_OUTPUT");

  }

}

2 个答案:

答案 0 :(得分:5)

调用

->Release()

相当于

camera.setFilters(Color::darker);

(如果您使用的是Java-8之前的匿名内部类)。您可以看到添加Color不需要setFilters(new Function<Color, Color>() { @Override public Color apply(Color color) { return color.darker(); } }); 或实现FunctionalInterface的所有样板文件 - 在较长的表单中,您将在Function内包装对此方法的调用

简化对lambda的这个调用给出了

Function

甚至更短:

setFilters((Function<Color, Color>) color -> color.darker());

最终可以简化为您的方法参考:

setFilters(color -> color.darker());

答案 1 :(得分:0)

Java AWT Color类(docs)有方法 brighter()darker(),因此调用实际上会传递这些函数。