關(guān)于Stream和Buffer的相互轉(zhuǎn)換詳解
前言
最近在工作的時候突然就有了這樣一個需求,這一次正好也對本來不太熟的 Stream 有了一點(diǎn)更加深刻的理解……(好吧本來是根本沒搞清楚狀況)。本文將給大家詳細(xì)介紹關(guān)于Stream和Buffer相互轉(zhuǎn)換的相關(guān)資料,下面話不多說,來一起看看詳細(xì)的介紹吧。
方法如下:
Stream,中文叫做流,和我們平時充值信仰的那個 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)換也很簡單:
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é)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
TypeScript類型系統(tǒng)自定義數(shù)據(jù)類型教程示例
這篇文章主要為大家介紹了TypeScript類型系統(tǒng)自定義數(shù)據(jù)類型教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11JavaScript實現(xiàn)元素滾動條到達(dá)一定位置循環(huán)追加內(nèi)容
下面小編就為大家分享一篇JavaScript實現(xiàn)元素滾動條到達(dá)一定位置循環(huán)追加內(nèi)容,具有很好的參考價值,希望對大家有所幫助2017-12-12bootstrap常用組件之頭部導(dǎo)航實現(xiàn)代碼
這篇文章主要介紹了bootstrap常用組件之頭部導(dǎo)航實現(xiàn)代碼,然后對個別常用屬性進(jìn)行了解釋,需要的的朋友參考下吧2017-04-04JavaScript html5利用FileReader實現(xiàn)上傳功能
這篇文章主要為大家詳細(xì)介紹了JavaScript html5利用FileReader實現(xiàn)上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03js創(chuàng)建一個input數(shù)組并綁定click事件的方法
這篇文章主要介紹了js創(chuàng)建一個input數(shù)組并綁定click事件的方法,需要的朋友可以參考下2014-06-06