成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官:說說對 Node 中的 Stream 的理解?應用場景?

大數據
流(Stream),是一種數據傳輸手段,是端到端信息交換的一種方式,是有順序的,是逐塊讀取數據、處理內容,用于順序讀取輸入或寫入輸出.

[[404387]]

 本文轉載自微信公眾號「JS每日一題」,作者灰灰 。轉載本文請聯系JS每日一題公眾號。

一、是什么

流(Stream),是一種數據傳輸手段,是端到端信息交換的一種方式,是有順序的,是逐塊讀取數據、處理內容,用于順序讀取輸入或寫入輸出

在很多時候,流(Stream)是字節流(Byte Steram)的簡稱,也就是長長的一串字節

除了字節流,還可以有視頻流、音頻流、數據流

流的獨特之處在于,它不像傳統的程序那樣一次將一個文件讀入內存,而是逐塊讀取數據、處理其內容,而不是將其全部保存在內存中

流可以分成三部分:source、dest、pipe

在source和dest之間有一個連接的管道pipe,它的基本語法是source.pipe(dest),source和dest就是通過pipe連接,讓數據從source流向了dest,如下圖所示:

二、種類

在NodeJS,幾乎所有的地方都使用到了流的概念,分成四個種類:

可寫流:可寫入數據的流。例如 fs.createWriteStream() 可以使用流將數據寫入文件

  • 可讀流:可讀取數據的流。例如fs.createReadStream() 可以從文件讀取內容
  • 雙工流:既可讀又可寫的流。例如 net.Socket
  • 轉換流:可以在數據寫入和讀取時修改或轉換數據的流。例如,在文件壓縮操作中,可以向文件寫入壓縮數據,并從文件中讀取解壓數據

在NodeJS中HTTP服務器模塊中,request 是可讀流,response 是可寫流。還有fs 模塊,能同時處理可讀和可寫文件流

可讀流和可寫流都是單向的,比較容易理解,而另外兩個是雙向的

雙工流

之前了解過websocket通信,是一個全雙工通信,發送方和接受方都是各自獨立的方法,發送和接收都沒有任何關系

如下圖所示:

基本代碼如下:

  1. const { Duplex } = require('stream'); 
  2.  
  3. const myDuplex = new Duplex({ 
  4.   read(size) { 
  5.     // ... 
  6.   }, 
  7.   write(chunk, encoding, callback) { 
  8.     // ... 
  9.   } 
  10. }); 

轉換流

轉換流的演示圖如下所示:

比如一個 babel,把es6轉換為es5,我們在左邊寫入 es6,從右邊讀取 es5

基本代碼如下所示:

  1. const { Transform } = require('stream'); 
  2.  
  3. const myTransform = new Transform({ 
  4.   transform(chunk, encoding, callback) { 
  5.     // ... 
  6.   } 
  7. }); 

三、應用場景

stream的應用場景主要就是處理IO操作,而http請求和文件操作都屬于IO操作

思想一下,如果一次IO操作過大,硬件的開銷就過大,而將此次大的IO操作進行分段操作,讓數據像水管一樣流動,知道流動完成

常見的場景有:

  • get請求返回文件給客戶端
  • 文件操作
  • 一些打包工具的底層操作

get請求返回文件給客戶端

使用stream流返回文件,res也是一個stream對象,通過pipe管道將文件數據返回

  1. const server = http.createServer(function (req, res) { 
  2.     const method = req.method; // 獲取請求方法 
  3.     if (method === 'GET') { // get 請求 
  4.         const fileName = path.resolve(__dirname, 'data.txt'); 
  5.         let stream = fs.createReadStream(fileName); 
  6.         stream.pipe(res); // 將 res 作為 stream 的 dest 
  7.     } 
  8. }); 
  9. server.listen(8000); 

文件操作

創建一個可讀數據流readStream,一個可寫數據流writeStream,通過pipe管道把數據流轉過去

  1. const fs = require('fs'
  2. const path = require('path'
  3.  
  4. // 兩個文件名 
  5. const fileName1 = path.resolve(__dirname, 'data.txt'
  6. const fileName2 = path.resolve(__dirname, 'data-bak.txt'
  7. // 讀取文件的 stream 對象 
  8. const readStream = fs.createReadStream(fileName1) 
  9. // 寫入文件的 stream 對象 
  10. const writeStream = fs.createWriteStream(fileName2) 
  11. // 通過 pipe執行拷貝,數據流轉 
  12. readStream.pipe(writeStream) 
  13. // 數據讀取完成監聽,即拷貝完成 
  14. readStream.on('end'function () { 
  15.     console.log('拷貝完成'
  16. }) 

一些打包工具的底層操作

目前一些比較火的前端打包構建工具,都是通過node.js編寫的,打包和構建的過程肯定是文件頻繁操作的過程,離不開stream,如gulp

參考文獻

https://xie.infoq.cn/article/1a9695020828460eb3c4ff1fa

 

https://juejin.cn/post/6844903891083984910

 

責任編輯:武曉燕 來源: JS每日一題
相關推薦

2021-06-07 09:41:48

NodeBuffer 網絡協議

2021-05-31 10:35:34

TCPWebSocket協議

2021-07-12 08:35:24

組件應用場景

2021-07-07 08:36:45

React應用場景

2021-06-10 07:51:07

Node.js循環機制

2021-09-16 07:52:18

算法應用場景

2021-06-03 08:14:01

NodeProcessJavaScript

2021-09-06 10:51:27

TypeScriptJavaScript

2021-06-30 07:19:36

React事件機制

2021-06-01 08:25:06

Node.jsJavaScript運行

2021-11-05 07:47:56

代理模式對象

2021-11-09 08:51:13

模式命令面試

2021-06-04 07:55:30

Node Fs 操作

2021-11-10 07:47:49

組合模式場景

2021-11-03 14:10:28

工廠模式場景

2021-11-04 06:58:32

策略模式面試

2021-08-16 08:33:26

git

2021-09-08 07:49:34

TypeScript 泛型場景

2021-09-28 07:12:09

測試路徑

2021-11-11 16:37:05

模板模式方法
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 2020国产在线 | 宅女噜噜66国产精品观看免费 | 亚洲人成人一区二区在线观看 | 久久久91精品国产一区二区三区 | 日韩精品一区二区三区视频播放 | 久久精品视频一区二区三区 | 日本一区二区三区免费观看 | 久久专区 | 青青操av | 91成人在线视频 | 黄色一级大片视频 | 久久天堂 | 日韩精品久久一区二区三区 | 成人福利网站 | 亚洲理论在线观看电影 | 日韩精品免费在线观看 | 欧美日韩久 | 成人午夜电影在线观看 | 亚洲成人国产综合 | 国产免费一级片 | 尹人av| 欧美天堂| 亚洲 欧美 在线 一区 | 色婷婷精品国产一区二区三区 | 久久综合一区 | 中文字幕一区在线观看视频 | 亚洲色综合 | 一级黄色日本片 | 日韩美女在线看免费观看 | 成人特区| 国产精品一二三区 | 91久久精品一区二区三区 | 丝袜 亚洲 另类 欧美 综合 | 免费a在线 | 色婷婷av一区二区三区软件 | www四虎影视 | 99精品99 | 91五月天| 一级美国黄色片 | 亚洲一区二区黄 | 夜夜操天天艹 |