【发布时间】:2016-06-06 12:52:54
【问题描述】:
我有 2 节课:
class M {
public <R, A, T extends A> A walk(BiFunction<Widget, Integer, Stream<R>> walker, BiFunction<A, Stream<R>, T> accF, A acc, int level) {
return accF.apply(acc, walker.apply(this, level));
}
}
和
class N extends M {
public Stream<M> getChildren() {return Stream.of(new M()...);}
@Override
public <RR, A, T extends A> T walk(BiFunction<Widget, Integer, Stream<RR>> walker, BiFunction<A, Stream<RR>, T> accF, A acc, int level) {
return accF.apply(accF.apply(acc, walker.apply(this, level)), getChildren().map(o -> o.walk(walker, accF, acc, level + 1)));
}
}
但是,编译器在o.walk(walker, accF, acc, level + 1) 说inference variable T has incompatible bounds: equality constraints: T upper bounds: A, Object, RR
为什么会这样,我该如何解决这个问题?
【问题讨论】:
-
这是你如何让别人痛苦的方式吗?
-
@MuratK。呵呵 :) 好吧,也许它看起来有点复杂.. 但这只是一个递归树访问者.. 至于这里的类型,它在 Scala 编程中很常见.. 不被视为世界之外的东西.. Java 的 idk虽然..
-
你能把它编译成 except 以解决问题中的实际错误吗? IE。
Widget和...是什么? -
我对这里的 lambda 语法不太熟悉,但如果我没记错的话,
map()方法应该返回一个Stream<RR>类型的值,因为这就是accF的定义方式。但是,由于您还将accF传递给o.walk(),因此您正试图返回一个不适合的T类型的值。
标签: java generics recursion lambda type-inference