[英]Highland.js and buffer(or queue)
所以,我有下面的代码来模拟这个问题:
const H = require('highland');
const Promise = require('bluebird');
let i = 0
const stream = H(function(push, next) {
console.log('read', i)
push(null, i)
i++;
Promise.delay(100).then(() => next())
})
stream
.flatMap(function(x) {
console.log('start writing', x)
return H(Promise.delay(2000, 'y').tap(() => console.log('finish writing', x)))
})
.done()
产生这样的输出:
read 0
start writing 0
finish writing 0
read 1
start writing 1
问题:我希望有一个一定大小的缓冲区,在该缓冲区中可以堆叠生产者的数据。 因此,使用大小为1的缓冲区,输出应如下所示:
read 0
start writing 0
read 1
finish writing 0
start writing 1
read 2
因此,如果“生产者”很忙,我想缓冲生产者的价值。 可以在高地做这样的事情吗?
不。这是不可能的(不是通过诺言,而是通过回调实现),而且他们确实在这个冗长的问题线程中声明了这一点
我决定写scramjet的原因之一。
像您这样的简单案例:
let i = 0;
const stream = new (require("scramjet").DataStream)({read() { this.push(i++); })
stream.map(
(x) => Promise.delay(2000, 'y').tap(() => console.log('finish writing', x))
).accumulate(
() => 0
).then(
() => console.log("done")
)
它只是按您想要的方式工作。 :)
答案在我的北极
这里的想法–缓冲是流api的一部分。 高地只是操纵溪流
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.