簡體   English   中英

節點 - 管道 process.stdout 不會自動排出

[英]Node - piping process.stdout doesn't drain automatically

考慮這個可讀的 stream:

class ReadableStream extends stream.Readable {
  constructor() {
    super({objectMode:true, highWaterMark:128});
  }

  i = 0;
  _read(size: number) {
    while (this.push({key:this.i++})){}
  }
}

管道到 process.stdout 不會自動耗盡它。 沒有任何反應,程序退出。

new ReadableStream().pipe(process.stdout);

現在,讓我們將 pipe 改為可寫 stream:

class WritableStream extends stream.Writable {
  constructor() {
    super({objectMode:true, highWaterMark:128});
  }

  _write(chunk: any, encoding: string, callback: (error?: (Error | null)) => void) {
    console.log(chunk);
    callback();
  }
}

new ReadableStream().pipe(new WritableStream());

控制台立即充滿數字,因此它進入無窮大。

為什么 process.stdout 或 fs.createWriteStream 會自動請求數據?

process.stdout不是 object 模式 stream,當您使用 pipe 和 object 模式 stream 時無法正常工作。 如果您將 readableStream 更改為不是 object 模式 stream,則.pipe()將正常工作。

事實上,如果您為error事件附加一個事件處理程序,例如:

new ReadableStream().pipe(process.stdout).on('error', err => {
    console.log(err);
});

然后,你會得到這個:

TypeError [ERR_INVALID_ARG_TYPE]: The "chunk" argument must be one of type string or Buffer. Received type object
    at validChunk (_stream_writable.js:268:10)
    at WriteStream.Writable.write (_stream_writable.js:303:21)
    at ReadableStream.ondata (_stream_readable.js:727:22)
    at ReadableStream.emit (events.js:210:5)
    at ReadableStream.Readable.read (_stream_readable.js:525:10)
    at flow (_stream_readable.js:1000:34)
    at resume_ (_stream_readable.js:981:3)
    at processTicksAndRejections (internal/process/task_queues.js:80:21) {
  code: 'ERR_INVALID_ARG_TYPE'
}

這表明標准輸出不期望獲得 object。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM