Node.js學(xué)習(xí)筆記(七、Buffer緩沖區(qū)

      網(wǎng)友投稿 940 2025-03-31

      avaScript 語言自身只有字符串?dāng)?shù)據(jù)類型,沒有二進制數(shù)據(jù)類型。

      但在處理像TCP流或文件流時,必須使用到二進制數(shù)據(jù)。因此在 Node.js中,定義了一個 Buffer 類,該類用來創(chuàng)建一個專門存放二進制數(shù)據(jù)的緩存區(qū)。

      在 Node.js 中,Buffer 類是隨 Node 內(nèi)核一起發(fā)布的核心庫。Buffer 庫為 Node.js 帶來了一種存儲原始數(shù)據(jù)的方法,可以讓 Node.js 處理二進制數(shù)據(jù),每當(dāng)需要在 Node.js 中處理I/O操作中移動的數(shù)據(jù)時,就有可能使用 Buffer 庫。原始數(shù)據(jù)存儲在 Buffer 類的實例中。一個 Buffer 類似于一個整數(shù)數(shù)組,但它對應(yīng)于 V8 堆內(nèi)存之外的一塊原始內(nèi)存。

      Buffer 提供了以下 API 來創(chuàng)建 Buffer 類:

      Buffer.alloc(size[, fill[, encoding]]): 返回一個指定大小的 Buffer 實例,如果沒有設(shè)置 fill,則默認填滿 0

      Buffer.allocUnsafe(size): 返回一個指定大小的 Buffer 實例,但是它不會被初始化,所以它可能包含敏感的數(shù)據(jù)

      Buffer.allocUnsafeSlow(size)

      Buffer.from(array): 返回一個被 array 的值初始化的新的 Buffer 實例(傳入的 array 的元素只能是數(shù)字,不然就會自動被 0 覆蓋)

      Buffer.from(arrayBuffer[, byteOffset[, length]]): 返回一個新建的與給定的 ArrayBuffer 共享同一內(nèi)存的 Buffer。

      Buffer.from(buffer): 復(fù)制傳入的 Buffer 實例的數(shù)據(jù),并返回一個新的 Buffer 實例

      Node.js學(xué)習(xí)筆記(七、Buffer緩沖區(qū))

      Buffer.from(string[, encoding]): 返回一個被 string 的值初始化的新的 Buffer 實例

      // 創(chuàng)建一個長度為 10、且用 0 填充的 Buffer。 const buf1 = Buffer.alloc(10); // 創(chuàng)建一個長度為 10、且用 0x1 填充的 Buffer。 const buf2 = Buffer.alloc(10, 1); // 創(chuàng)建一個長度為 10、且未初始化的 Buffer。 // 這個方法比調(diào)用 Buffer.alloc() 更快, // 但返回的 Buffer 實例可能包含舊數(shù)據(jù), // 因此需要使用 fill() 或 write() 重寫。 const buf3 = Buffer.allocUnsafe(10); // 創(chuàng)建一個包含 [0x1, 0x2, 0x3] 的 Buffer。 const buf4 = Buffer.from([1, 2, 3]); // 創(chuàng)建一個包含 UTF-8 字節(jié) [0x74, 0xc3, 0xa9, 0x73, 0x74] 的 Buffer。 const buf5 = Buffer.from('tést'); // 創(chuàng)建一個包含 Latin-1 字節(jié) [0x74, 0xe9, 0x73, 0x74] 的 Buffer。 const buf6 = Buffer.from('tést', 'latin1');

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      15

      16

      17

      18

      19

      20

      語法:

      buf.write(string[, offset[, length]][, encoding])

      1

      參數(shù):

      string - 寫入緩沖區(qū)的字符串。

      offset - 緩沖區(qū)開始寫入的索引值,默認為 0 。

      length - 寫入的字節(jié)數(shù),默認為 buffer.length

      encoding - 使用的編碼。默認為 ‘utf8’ 。

      根據(jù) encoding 的字符編碼寫入 string 到 buf 中的 offset 位置。 length 參數(shù)是寫入的字節(jié)數(shù)。 如果 buf 沒有足夠的空間保存整個字符串,則只會寫入 string 的一部分。 只部分解碼的字符不會被寫入。

      實例:

      buf = Buffer.alloc(256); len = buf.write("hey,boy,goldblessyou"); console.log("寫入字節(jié)數(shù) : "+ len);

      1

      2

      3

      4

      運行:

      語法:

      buf.toString([encoding[, start[, end]]])

      1

      參數(shù):

      encoding - 使用的編碼。默認為 ‘utf8’ 。

      start - 指定開始讀取的索引位置,默認為 0。

      end - 結(jié)束位置,默認為緩沖區(qū)的末尾。

      返回值

      解碼緩沖區(qū)數(shù)據(jù)并使用指定的編碼返回字符串。

      實例:

      bufferread.js,

      buf = Buffer.alloc(26); for (var i = 0 ; i < 26 ; i++) { buf[i] = i + 97; } console.log( buf.toString('ascii')); // 輸出: abcdefghijklmnopqrstuvwxyz console.log( buf.toString('ascii',0,5)); // 輸出: abcde console.log( buf.toString('utf8',0,5)); // 輸出: abcde console.log( buf.toString(undefined,0,5)); // 使用 'utf8' 編碼, 并輸出: abcde

      1

      2

      3

      4

      5

      6

      7

      8

      9

      運行:

      語法:

      buf.toJSON()

      1

      當(dāng)字符串化一個 Buffer 實例時,JSON.stringify() 會隱式地調(diào)用該 toJSON()。

      實例:

      bufjson.js,

      const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]); const json = JSON.stringify(buf); // 輸出: {"type":"Buffer","data":[1,2,3,4,5]} console.log(json); const copy = JSON.parse(json, (key, value) => { return value && value.type === 'Buffer' ? Buffer.from(value.data) : value; }); // 輸出: console.log(copy);

      1

      2

      3

      4

      5

      6

      7

      8

      9

      10

      11

      12

      13

      14

      運行:

      參考:

      【1】、https://www.w3cschool.cn/nodejs/nodejs-buffer.html

      【2】、https://www.runoob.com/nodejs/nodejs-buffer.html

      javaScript Node.js

      版權(quán)聲明:本文內(nèi)容由網(wǎng)絡(luò)用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔(dān)相應(yīng)法律責(zé)任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。

      版權(quán)聲明:本文內(nèi)容由網(wǎng)絡(luò)用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔(dān)相應(yīng)法律責(zé)任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。

      上一篇:請假流程圖制作模板(員工請假流程圖表)
      下一篇:如何在WPS演示中插入圖片
      相關(guān)文章
      中文字幕亚洲图片| 亚洲欧美日韩久久精品| 亚洲爆乳精品无码一区二区| 亚洲国产成人久久77| 亚洲精品高清视频| 久久亚洲精品无码| 亚洲av无码国产精品色午夜字幕| 亚洲乱码国产一区三区| 亚洲中文字幕在线观看| 亚洲精品网站在线观看不卡无广告| 噜噜噜亚洲色成人网站| 亚洲国产精品综合久久一线| 亚洲精品国产综合久久一线| 亚洲欧洲一区二区三区| 亚洲国产一区二区视频网站| 亚洲AV无码AV日韩AV网站| 久久精品国产亚洲AV电影网| 小说区亚洲自拍另类| 日韩精品成人亚洲专区| 亚洲日本va午夜中文字幕久久| 亚洲国产成人VA在线观看| 亚洲情侣偷拍精品| 久久亚洲精品无码观看不卡| 亚洲热线99精品视频| 亚洲av无码不卡一区二区三区| 亚洲网址在线观看你懂的| 亚洲精品中文字幕麻豆| 亚洲精品第一国产综合野| 亚洲日韩国产二区无码| 鲁死你资源站亚洲av| 亚洲精品456播放| 亚洲人成中文字幕在线观看| 亚洲av无码成人黄网站在线观看| 亚洲男人天堂2017| 亚洲大香人伊一本线| 亚洲日本成本人观看| va亚洲va日韩不卡在线观看| 久久久久国产亚洲AV麻豆| 亚洲国产精品无码中文字| 亚洲精品电影在线| 亚洲人成色777777精品|