您正在尝试使用错误的接口类型。在这种情况下,函数类型是不合适的,因为它会接收参数并具有返回值。相反,您应该使用Consumer(以前称为Block)
函数类型声明为
interface Function<T,R> { R apply(T t);}
但是,消费者类型与您要查找的类型兼容:
interface Consumer<T> { void accept(T t);}
这样,Consumer与接收T且不返回任何值(无效)的方法兼容。这就是您想要的。
例如,如果我想显示列表中的所有元素,我可以简单地使用lambda表达式为其创建使用者:
List<String> allJedi = asList("Luke","Obiwan","Quigon");allJedi.forEach( jedi -> System.out.println(jedi) );
您可以在上面看到,在这种情况下,lambda表达式接收一个参数并且没有返回值。
现在,如果我想使用方法引用而不是lambda表达式来创建这种类型的消耗,那么我需要一个可以接收String并返回void的方法,对吗?
我可以使用不同类型的方法引用的,但在这种情况下,让一个对象的方法引用的占据优势,通过使用
println该方法
System.out的对象,像这样:
Consumer<String> block = System.out::println
或者我可以简单地做
allJedi.forEach(System.out::println);
该
println方法是适当的,因为它接收一个值并且具有返回类型void,就像
acceptConsumer中的方法一样。
因此,在您的代码中,您需要将方法签名更改为:
public static void myForEach(List<Integer> list, Consumer<Integer> myBlock) { list.forEach(myBlock);}
然后,您应该能够通过以下方式使用静态方法引用创建使用者:
myForEach(theList, Test::displayInt);
最终,您甚至可以
myForEach完全摆脱方法,只需执行以下 *** 作:
theList.forEach(Test::displayInt);
关于作为头等公民的职能
所有人都说过,事实是Java
8将不具有作为一等公民的功能,因为不会将结构函数类型添加到该语言中。Java将简单地提供一种替代方法,以通过lambda表达式和方法引用来创建功能接口的实现。最终,lambda表达式和方法引用将绑定到对象引用,因此,我们所拥有的只是作为一等公民的对象。重要的是功能在这里,因为我们可以将对象作为参数传递,将它们绑定到变量引用,然后将它们作为其他方法的值返回,那么它们的作用差不多。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)