是否有更好的方法(即通过删除Materializer
约束)来实现以下方法:
import akka.NotUsed
import akka.stream.Materializer
import akka.stream.scaladsl.{Keep, Sink, Source}
def assemble[A, B, C](source: Source[A, NotUsed])
(f: A => Source[B, NotUsed], g: A => Sink[B, C])
(implicit m: Materializer): Source[C, NotUsed] = {
source.map(a => f(a).toMat(g(a))(Keep.right).run())
}
答案 0 :(得分:2)
基本上,你是在实现了一堆图表并创建了一个Source
的物化价值。
如果没有Materializer
参数,我就没有办法做到这一点。
如果它有帮助,你可以用更紧凑的方式编写你的方法
source.map(a => f(a).runWith(g(a)))