前言
在開封等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站建設(shè)、成都做網(wǎng)站 網(wǎng)站設(shè)計(jì)制作按需定制設(shè)計(jì),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),高端網(wǎng)站設(shè)計(jì),營(yíng)銷型網(wǎng)站,外貿(mào)網(wǎng)站制作,開封網(wǎng)站建設(shè)費(fèi)用合理。
最近在工作的時(shí)候突然就有了這樣一個(gè)需求,這一次正好也對(duì)本來不太熟的 Stream 有了一點(diǎn)更加深刻的理解……(好吧本來是根本沒搞清楚狀況)。本文將給大家詳細(xì)介紹關(guān)于Stream和Buffer相互轉(zhuǎn)換的相關(guān)資料,下面話不多說,來一起看看詳細(xì)的介紹吧。
方法如下:
Stream,中文叫做流,和我們平時(shí)充值信仰的那個(gè) Steam 還是差了那么一點(diǎn)的。所謂流,是一種消費(fèi)的模型,被消費(fèi)完就木有了,所以如果我們需要重復(fù)使用,就得存下來,也就是把 Stream 轉(zhuǎn)成別的東西——Just Like Array or Buffer。
上代碼表演一下:
function streamToBuffer(stream) { return new Promise((resolve, reject) => { let buffers = []; stream.on('error', reject); stream.on('data', (data) => buffers.push(data)) stream.on('end', () => resolve(Buffer.concat(buffers)) }); }
Buffer.concat(buffers)
之后就轉(zhuǎn)換為了 Buffer,可以重復(fù)使用了。
逆向轉(zhuǎn)換也很簡(jiǎn)單:
let Duplex = require('stream').Duplex; function bufferToStream(buffer) { let stream = new Duplex(); stream.push(buffer); stream.push(null); return stream; }
參考:
http://derpturkey.com/buffer-to-stream-in-node/
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。