我已经解决了一个Y组合器的问题。刚刚我发现我不能递归地引用一个泛型参数。
Y = λf.(λx.f (x x)) (λx.f (x x))
例如:
IntUnaryOperator fact = Y(rec -> n -> n == 0 ? 1 : n * rec.applyAsInt(n - 1));
IntUnaryOperator Y(Function<IntUnaryOperator, IntUnaryOperator> f) {
return g(g -> f.apply(x -> g.apply(g).applyAsInt(x)));
}
IntUnaryOperator g(G g) {
return g.apply(g);
}
// v--- I want to remove the middle-interface `G`
interface G extends Function<G, IntUnaryOperator> {/**/}
问题:如何在方法g
上使用泛型参数,避免引入额外的接口G
,并且泛型参数应该避免UNCHECKED
警告?
谢谢。