瞭解nodeJs中的流(stream)

是我放火燒了雨發表於2018-04-09

Nodejs中的很多地方都用到了流,流是一個很常見的概念,一個http請求,控制檯輸入輸出的形式都是流。流可以分為三種:

可讀流(Readable)
可寫流(Writable )
既能讀又能寫(Duplex )

其中第三種流又可以分為全雙工流Duplex和轉換流Transform,另外,所有的流都是EventEmitter的例項,
也就是有傳送事件和處理事件的能力。
複製程式碼

可讀流 Readable Stream

可讀流可以輸出資料,常見的可讀流有:

http請求和響應

讀檔案

壓縮解壓

加密解密

tcp sockect

程式輸入
複製程式碼

可讀流分為兩種模式:流式的和非流式的,區別就是前者會盡快保證資料可用,而後者則是隻有等到你主動呼叫stream.read()之後才可用。

剛才說過,所有的流都是EventEmitter的例項,它本身也有一些內建的事件,ReadableStream有的事件包括:

readable: 流中的資料已經準備就緒

data: 有資料到來,對應flowing模式

end: 沒有更多的資料了

close: 有關的資源如檔案描述符被關閉時觸發

error: 接收資料時發生錯誤
複製程式碼

另外還有一些方法介面:

read([size]): 主動的拉取一定的資料,如果沒有資料,則返回null,如果size不傳,則返回所有可用的資料。
該方法只能在non-flowing模式下呼叫

setEncoding(encoding): 使用什麼樣的編碼格式進行解析

pause(): 停止傳送data事件,新來的資料會保留到內部的buffer中

resume(): 對應上個事件,恢復data事件的傳送

pipe(destination, [option]):從流中拉取資料,並寫入到destination流中,因為返回的是destination流,
因此可以使用鏈式操作;預設情況下,讀取流關閉後寫入流也被關閉

unpipe([destination]): 將pipe方法設定的寫入規則移除掉,如果不傳入destination,則移除所有的流

unshift(chunk): 可以想象為把吐出來的東西再吃進去,這裡就是把讀取出來的部分或全部內容再次放到可讀流中

wrap(stream): 對老式的流進行包裝
複製程式碼

可寫流 Writable Stream

同樣的,可寫流有事件和方法兩部分,事件包括:

drain: 表明資料還沒有寫完,write方法呼叫返回false

finish: 所有的資料都寫入完畢

pipe: 當一個讀取流呼叫pipe方法指向當前寫入流

unpipe: 當一個讀取流呼叫unpipe方法將當前寫入流撤銷時

error: 寫入出現錯誤時
複製程式碼

方法:

write(chunk,[encoding],[callback]): 寫入資料,當資料必須要在內部被緩衝時,返回false

end([chunk],[encoding],[callback]): 寫完之後就終止新的寫入了
複製程式碼

可讀寫流

Duplex: 全雙工的流,可讀可寫

Transform: 從input中讀取流資料,進行處理後寫入到output流中
複製程式碼

(由於本次時間較緊,後續會寫一些程式碼放上來進一步瞭解深入)

相關文章