溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在node.js中使用stream模塊

發(fā)布時(shí)間:2021-03-18 16:12:42 來源:億速云 閱讀:128 作者:Leah 欄目:web開發(fā)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)怎么在node.js中使用stream模塊,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一、實(shí)現(xiàn)自定義的可讀流

實(shí)現(xiàn)可讀流需繼承 stream.Readable,并實(shí)現(xiàn) readable._read() 方法。

下面的代碼我們實(shí)現(xiàn)了一個(gè)從數(shù)組中讀取數(shù)據(jù)的流

const {Readable} = require('stream');
//這里我們自定義了一個(gè)用來讀取數(shù)組的流
class ArrRead extends Readable {
  constructor(arr, opt) {
    //注意這里,需調(diào)用父類的構(gòu)造函數(shù)
    super(opt);
    this.arr = arr;
    this.index = 0;
  }
  //實(shí)現(xiàn) _read() 方法
  _read(size) {
    //如果當(dāng)前下標(biāo)等于數(shù)組長(zhǎng)度,說明數(shù)據(jù)已經(jīng)讀完
    if (this.index == this.arr.length) {
      this.push(null);
    } else {
      this.arr.slice(this.index, this.index + size).forEach((value) => {
        this.push(value.toString());
      });
      this.index += size;
    }
  }
}
let arr = new ArrRead([1, 2, 3, 4, 5, 6, 7, 8, 9, 0], {
  highWaterMark: 2
});
//這樣當(dāng)我們監(jiān)聽 'data' 事件時(shí),流會(huì)調(diào)用我們實(shí)現(xiàn)的 _read() 方法往緩沖區(qū)中讀取數(shù)據(jù)
//然后提供給消費(fèi)者
arr.on('data', function (data) {
  console.log(data.toString());
});

二、實(shí)現(xiàn)自定義的可寫流

實(shí)現(xiàn)可寫流必須繼承 stream.Writeable ,并實(shí)現(xiàn) writeable._write() 方法。writable._writev() 方法是可選的。

const {Writable} = require('stream');
//這里我們自定義了一個(gè)用來寫入數(shù)組的流
class ArrWrite extends Writable {
  constructor(arr, opt) {
    super(opt);
    this.arr = arr;
  }
  //實(shí)現(xiàn) _write() 方法
  _write(chunk, encoding, callback) {
    this.arr.push(chunk.toString());
    callback();
  }
}
let data = [];
let arr = new ArrWrite(data, {
  highWaterMark: 3
});
arr.write('1');
arr.write('2');
arr.write('3');
console.log(data);

三、實(shí)現(xiàn)自定義的可讀可寫流

可讀可寫流必須繼承 stream.Duplex,并實(shí)現(xiàn) readable._read() 和 writable._write() 方法。

const {Duplex} = require('stream');
//這里我們自定義了一個(gè)用來寫讀可寫數(shù)組的流
class ArrReadWrite extends Duplex {
  constructor(arr, opt) {
    super(opt);
    this.arr = arr;
    this.index = 0;
  }
  //實(shí)現(xiàn) _write() 方法
  _write(chunk, encoding, callback) {
    this.arr.push(chunk.toString());
    callback();
  }
  //實(shí)現(xiàn) _read() 方法
  _read(size) {
    //如果當(dāng)前下標(biāo)等于數(shù)組長(zhǎng)度,說明數(shù)據(jù)已經(jīng)讀完
    if (this.index == this.arr.length) {
      this.push(null);
    } else {
      this.arr.slice(this.index, this.index + size).forEach((value) => {
        this.push(value.toString());
      });
      this.index += size;
    }
  }
}
let data = [];
let arrWR = new ArrReadWrite(data, {
  highWaterMark: 3
});
//往流中寫入數(shù)據(jù)
arrWR.write('1');
arrWR.write('2');
arrWR.write('3');
console.log(data);
//往流中讀取數(shù)據(jù)
console.log(arrWR.read(2).toString());
console.log(arrWR.read(2).toString());

四、自定義的轉(zhuǎn)換流

轉(zhuǎn)換流必須繼承 stream.Transform,需實(shí)現(xiàn) transform._transform() 方法。

const {Transform} = require('stream');
//這里我們自定義了一個(gè)用來轉(zhuǎn)換數(shù)組的流
class Trans extends Transform {
  constructor(opt) {
    super(opt);
  }
  _transform(chunk, encoding, callback) {
    //將轉(zhuǎn)換后的數(shù)據(jù)輸出到可讀流
    this.push(chunk.toString().toUpperCase());
    //參數(shù)一是Error對(duì)象
    //參數(shù)二如果傳入,會(huì)被轉(zhuǎn)發(fā)到 readable.push()
    callback();
  }
}
let t = new Trans({
  highWaterMark: 3
});
t.on('data', function (data) {
  console.log(data.toString());
});
t.write('a');
t.write('b');
t.write('c');

轉(zhuǎn)換流就是將讀取到的數(shù)據(jù)做些計(jì)算然后輸出。轉(zhuǎn)換流既可以作為可讀流,又可以作為可寫流。

const {Transform} = require('stream');
//這里我們自定義了一個(gè)用來轉(zhuǎn)換數(shù)組的流
class Trans extends Transform {
  constructor(opt) {
    super(opt);
  }
  _transform(chunk, encoding, callback) {
    //將轉(zhuǎn)換后的數(shù)據(jù)輸出到可讀流
    this.push(chunk.toString().toUpperCase());
    //參數(shù)一是Error對(duì)象
    //參數(shù)二如果傳入,會(huì)被轉(zhuǎn)發(fā)到 readable.push()
    callback();
  }
}
let t = new Trans({
  highWaterMark: 3
});
t.on('data', function (data) {
  console.log('data', data.toString());
});
//stdin.pipe(t) 表示將我們的標(biāo)準(zhǔn)輸入寫入到我的轉(zhuǎn)換流 t 中,此時(shí) t 是可寫流。
//pipe(process.stdout) 表示將轉(zhuǎn)換流 t 中的數(shù)據(jù)讀取到標(biāo)準(zhǔn)輸出中,此時(shí) t 是可讀流。
process.stdin.pipe(t).pipe(process.stdout);

上述就是小編為大家分享的怎么在node.js中使用stream模塊了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI