Es gibt eine einfache Problemumgehung. Wickeln Sie einfach Ihr Schwanz rekursive Strom Verbraucher in einer anderen Funktion, die den Strom über einen by-name Parameter erhält:
import scala.annotation.tailrec
trait T {
def consume[A](as: => Stream[A]): Unit = {
@tailrec
def loop[A](as: Stream[A]): Unit = {
if (as.isEmpty)()
else loop(as.tail)
}
loop(as)
}
}
object O extends T {
def main(args: Array[String]): Unit =
O.consume(Range(1, 1000000000).toStream)
}
Der Spediteur Verfahren wird eine Referenz auf eine Funktion halten einen Ausdruck der Berechnung des Ergebnisses von dem ein Strom ist :
public final class O$ implements T {
public static final MODULE$;
// This is the forwarder:
public <A> void consume(Function0<Stream<A>> as) {
T.class.consume(this, as);
}
. . .
public void main(String[] args) {
consume(new AbstractFunction0() {
public final Stream<Object> apply() {
return package..MODULE$.Range().apply(1, 1000000000).toStream();
}
});
}
}
Siehe auch http://stackoverflow.com/questions/12529697/how-to-write-non-leaking-tail-recursive-stream-function-in-scala – ron