我不认为你想要一个 Process1,我认为如果你创建一个 Process1 ,你会创建一个 Process1[A, Task[B]] 这不是你想要的。
我认为您想创建一个Channel,您可以将Process 附加到它上面,这将为您提供一个新的Process。 Channel 只是产生有效功能的 Process 的别名。
type Channel[+F[_],-I,O] = Process[F, I => F[O]]
既然你有一个函数,你只需要创建一个进程来产生相同函数的无限流,constant
// a String => Task[Int] that we'll make a channel from
val length: String => Task[Int] = (x => Task.delay(x.length))
// a channel is just a source of functions:
val lengthChannel = Process.constant(length)
现在给定一个产生字符串的进程(这里我们只产生一个):
val source: Process[Task,String] = Process.emit("asdf")
我们可以通过我们的渠道运行我们的源来创建一个进程
val lengths = source through lengthChannel
我们可以运行我们的进程并获得“asdf”的长度
scala> lengths.runLog.run
res5: scala.collection.immutable.IndexedSeq[Int] = Vector(4)