Node.js學(xué)習(xí)筆記(七、Buffer緩沖區(qū))
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 實例
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; }); // 輸出:
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)容。