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流中
複製程式碼
(由於本次時間較緊,後續會寫一些程式碼放上來進一步瞭解深入)