Node.js中的Buffer對象及創(chuàng)建方式
什么是Buffer?
js語言自身只有字符串?dāng)?shù)據(jù)類型,沒有二進(jìn)制數(shù)據(jù)類型,而處理TCP和文件流的時候,必須處理二進(jìn)制數(shù)據(jù)。
node.js提供了一個Buffer對象來提供對二進(jìn)制數(shù)據(jù)的操作。
Buffer 類在 Node.js 中是一個全局變量,在使用時無需引入模塊,直接使用即可。
Buffer 類的實例類似于整數(shù)數(shù)組,但 Buffer 的大小是固定的、且在 V8 堆外分配物理內(nèi)存。 Buffer 的大小在被創(chuàng)建時確定,且無法調(diào)整。
注意
Buffer中存儲的都是二進(jìn)制數(shù)據(jù),但是在顯示時以16進(jìn)制顯示
Buffer中每一個元素的范圍從(00-ff)即(0-255)
let str = 'Hello word' let buf = Buffer.from(str); //將字符串保存到Buffer中 console.log(buf)//<Buffer 48 65 6c 6c 6f 20 77 6f 72 64>
Buffer.length表示占用內(nèi)存的大小
由于漢字占3字節(jié)所以buf.length打印出來是12,而字符串的長度為8。
let str = 'Hello 小萱' let buf = Buffer.from(str); console.log(str.length);//8 console.log(buf.length);//12
Buffer打印數(shù)字時會以十進(jìn)制方式顯示
我們創(chuàng)建長度為5的的Buffer對象,并向里面添加字符和數(shù)字如下,我們分別打印字符和數(shù)字時會發(fā)現(xiàn)打印數(shù)字時會以十進(jìn)制顯示。
let buf = Buffer.alloc(5); buf[0] = "a"; buf[1] = 10; buf[2] = 15; buf[3] = 20; buf[4] = 25; console.log(buf[1])//10 console.log(buf[2]);//15
Buffer的創(chuàng)建方法
通過Buffer的構(gòu)造函數(shù),但不推薦使用
如創(chuàng)建一個指定大小的Buffer,
let buf = new Buffer(10); console.log(buf);//<Buffer 00 00 00 00 00 00 00 00 00 00>
我們打開node.js中文網(wǎng)官方文檔,發(fā)現(xiàn)Buffer的構(gòu)造方法全部都被棄用了,因此我就不重點寫這部分了
通過allocUnsafe方法
語法:
Buffer.allocUnsafe(size)
size
: 必選參數(shù),Buffer 所需的長度。
以這種方式創(chuàng)建的 Buffer 實例的底層內(nèi)存不會被初始化。 新創(chuàng)建的 Buffer 的內(nèi)容是未知的,可能包含敏感的數(shù)據(jù)。如果使用allocUnsafe方法,那么他在分配內(nèi)存時沒有清理數(shù)據(jù),如果被分配的內(nèi)存如果存在數(shù)據(jù),那么就會造成數(shù)據(jù)泄漏。但是它的性能優(yōu)于alloc方法。
let buf = Buffer.allocUnsafe(10); console.log(buf);//<Buffer 00 00 4a 00 00 3c 00 00 90 00>
通過alloc方法
語法:
Buffer.alloc(size[, fill[, encoding]])
size
:必選參數(shù), Buffer 所需的長度。
fill
:可選參數(shù),用于預(yù)填充新 Buffer 的值。 默認(rèn)值: 0。
encoding
:可選參數(shù),如果 fill 是字符串,則這就是它的編碼。 默認(rèn)值: ‘utf8’。
創(chuàng)建一個指定大小為10的Buffer對象。
其中傳入必選參數(shù)10,那么它默認(rèn)fill 為 undefined,則 Buffer 將以零填充。
再傳入可選參數(shù)fill為1,則以1填充
最后可以傳入fill的編碼格式,表示fill將以什么方式編碼
let buf = Buffer.alloc(10); console.log(buf);//<Buffer 00 00 00 00 00 00 00 00 00 00> let buf1 = Buffer.alloc(10,1) console.log(buf1);//<Buffer 01 01 01 01 01 01 01 01 01 01> let buf2 = Buffer.alloc(10,1,"utf8") console.log(buf2);//<Buffer 01 01 01 01 01 01 01 01 01 01>
alloc方法會初始化Buffer緩存區(qū),它可確保新創(chuàng)建的 Buffer 實例的內(nèi)容永遠(yuǎn)不會包含來自先前分配的敏感數(shù)據(jù),包括可能尚未分配給 Buffer 的數(shù)據(jù)。
通過Buffer.from()方法
1、通過數(shù)組創(chuàng)建
語法:
Buffer.from(array)
array
:必選參數(shù),用 0 – 255 范圍內(nèi)的字節(jié) array 分配新的 Buffer。 該范圍之外的數(shù)組條目將被截斷以符合它。
通過創(chuàng)建我們發(fā)現(xiàn)數(shù)組里面值的范圍為00-FF,同時不能是字符類型的值。
const buf = Buffer.from([1,3,5,7,4]); console.log(buf)//<Buffer 01 03 05 07 04> const buf1 = Buffer.from(["a","b","c"]); console.log(buf1)//<Buffer 00 00 00>
2、通過字符串創(chuàng)建
語法:
Buffer.from(string[, encoding])
string
:必選參數(shù) 要編碼的字符串。encoding
:可選參數(shù) string 的編碼。 默認(rèn)值: ‘utf8’。
const buf1 = Buffer.from('this is a example'); console.log(buf1);//<Buffer 74 68 69 73 20 69 73 20 61 20 65 78 61 6d 70 6c 65> //通過ToString方法將它轉(zhuǎn)化成字符串 console.log(buf1.toString())//this is a example
寫入緩沖區(qū)
語法:
buf.write(string[, offset[, length]][, encoding])
string
:必選參數(shù), 寫入緩沖區(qū)的字符串。
offset
:可選參數(shù),緩沖區(qū)開始寫入的索引值,默認(rèn)為 0 。
length
:可選參數(shù),寫入的字節(jié)數(shù),默認(rèn)為 buffer.length
encoding
:可選參數(shù),使用的編碼。默認(rèn)為 ‘utf8’ 。
返回值
:返回實際寫入的大小。如果 buffer 空間不足, 則只會寫入部分字符串。
const buf = Buffer.alloc(256); const len = buf.write("this is a example"); console.log("寫入字節(jié)數(shù) : "+len);//17
從緩沖區(qū)讀取數(shù)據(jù)
語法:
buf.toString([encoding[, start[, end]]])
encoding
:可選參數(shù),使用的編碼。默認(rèn)為 ‘utf8’ 。
start
:可選參數(shù),指定開始讀取的索引位置,默認(rèn)為 0。
end :可選參數(shù),結(jié)束位置,默認(rèn)為緩沖區(qū)的末尾。
返回值
:解碼緩沖區(qū)數(shù)據(jù)并使用指定的編碼返回字符串。
buf = Buffer.alloc(26); for (let i = 0 ; i < 26 ; i++) { buf[i] = i + 65; } console.log( buf.toString('ascii')); // 輸出:ABCDEFGHIJKLMNOPQRSTUVWXYZ console.log( buf.toString('ascii',0,10)); //使用 'ascii' 編碼, 并輸出:ABCDEFGHIJ console.log( buf.toString('utf8',10,15)); // 使用 'utf8' 編碼, 并輸出: KLMNO console.log( buf.toString(undefined,15,26)); // 使用默認(rèn)的 'utf8' 編碼, 并輸出: PQRSTUVWXYZ
將 Buffer 轉(zhuǎn)換為 JSON 對象
語法:
buf.toJSON()
返回值
:返回 JSON 對象。
const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]); const json = JSON.stringify(buf); console.log(json)//{"type":"Buffer","data":[1,2,3,4,5]}
拷貝緩沖區(qū)
語法:
buf.copy(targetBuffer[, targetStart[, sourceStart[, sourceEnd]]])
targetBuffer
- 必選參數(shù),要拷貝的 Buffer 對象。
targetStart
- 數(shù)字, 可選, 默認(rèn): 0
sourceStart
- 數(shù)字, 可選, 默認(rèn): 0
sourceEnd
- 數(shù)字, 可選, 默認(rèn): buffer.length
var buf1 = Buffer.from('ABCDEFGHIJKLMNOP'); var buf2 = Buffer.from('UVWXYZ'); //將 buf2 插入到 buf1 指定位置上 buf2.copy(buf1, 2); console.log(buf1.toString());
緩沖區(qū)與迭代器
可以使用 for…of 語法迭代 Buffer 實例:
通過迭代后會以十進(jìn)制顯示。
const buf = Buffer.from([oxc,2,3,4,5]); console.log(buf)//<Buffer 01 02 03 04 05> for (const b of buf) { console.log(b); } //12 // 2 // 3 // 4 // 5
const buf = Buffer.from('string'); console.log(buf)//<Buffer 73 74 72 69 6e 67> for (const b of buf) { console.log(b); } //115 // 116 // 114 // 105 // 110 // 103
總結(jié)
1、Buffer對象是Node處理二進(jìn)制數(shù)據(jù)的一個接口。它是Node原生提供的全局對象,可以直接使用。
2、網(wǎng)絡(luò)層對于不同資源的請求和響應(yīng)都是用二進(jìn)制的形式來交互的。javascript中的字符串是以utf-8的格式存儲的,處理二進(jìn)制的能力很弱,因此需要使用Buffer來處理二進(jìn)制數(shù)據(jù)。
到此這篇關(guān)于Node.js中的Buffer對象及創(chuàng)建方式的文章就介紹到這了,更多相關(guān)Node.js Buffer對象內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
async/await與promise(nodejs中的異步操作問題)
這篇文章主要介紹了async/await與promise(nodejs中的異步操作問題),非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03使用node.js半年來總結(jié)的 10 條經(jīng)驗
從3月初來到帝都某創(chuàng)業(yè)公司的服務(wù)器團(tuán)隊實習(xí),到現(xiàn)在已接近半年的時間。PS: 已轉(zhuǎn)正,服務(wù)器端用的 Node。2014-08-08Node.JS更改Windows注冊表Regedit的方法小結(jié)
注冊表是windows操作系統(tǒng)中的一個核心數(shù)據(jù)庫,這里介紹一些通過node.js操作注冊表的幾種方法,感興趣的朋友參考下吧2017-08-08