溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

node.js中Buffer緩沖器的原理是什么

發(fā)布時(shí)間:2021-03-23 15:14:25 來(lái)源:億速云 閱讀:235 作者:Leah 欄目:web開(kāi)發(fā)

本篇文章給大家分享的是有關(guān)node.js中Buffer緩沖器的原理是什么,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話(huà)不多說(shuō),跟著小編一起來(lái)看看吧。

一、什么是Buffer

Buffer緩沖器是用來(lái)存儲(chǔ)輸入和輸出數(shù)據(jù)的一段內(nèi)存。js語(yǔ)言沒(méi)有二進(jìn)制數(shù)據(jù)類(lèi)型,在處理TCP和文件流的時(shí)候,就不是很方便了。

所以node.js提供了Buffer類(lèi)來(lái)處理二進(jìn)制數(shù)據(jù),Buffer類(lèi)是一個(gè)全局變量,Buffer在創(chuàng)建的時(shí)候大小就固定了,無(wú)法改變。

Buffer類(lèi)的實(shí)例類(lèi)似于由字節(jié)元素組成的數(shù)組,可以有效的表示二進(jìn)制數(shù)據(jù)。

二、什么是字節(jié)

字節(jié)是計(jì)算機(jī)存儲(chǔ)時(shí)的一種計(jì)量單位,一個(gè)字節(jié)等于8個(gè)位。一個(gè)位就代表0或1,每8個(gè)位(bit)組成一個(gè)字節(jié)(byte)。

字節(jié)是網(wǎng)絡(luò)傳輸數(shù)據(jù)的基本單位,一個(gè)字節(jié)最大表示的十進(jìn)制數(shù)是255。

三、什么是進(jìn)制

進(jìn)制是人為定義的帶進(jìn)位的計(jì)數(shù)方法,常見(jiàn)的有二進(jìn)制,八進(jìn)制,十六進(jìn)制,和十進(jìn)制。

將任意數(shù)字轉(zhuǎn)換成不同進(jìn)制

console.log(parseInt('12', 2));
console.log(parseInt('12', 8));
console.log(parseInt('12', 16));
console.log(parseInt('12', 10));

轉(zhuǎn)換進(jìn)制的另一種方法:

console.log((10).toString(2));
console.log((10).toString(8));
console.log((10).toString(16));
console.log((10).toString(10));

四、創(chuàng)建Buffer的方法

通過(guò)Buffer.alloc來(lái)創(chuàng)建指定長(zhǎng)度Buffer

//創(chuàng)建6個(gè)字節(jié)的Buffer,用0填充數(shù)據(jù)
let buf1 = Buffer.alloc(6);
console.log(buf1);
//指定數(shù)字進(jìn)行填充
let buf2 = Buffer.alloc(6, 2);
console.log(buf2);
//也可以指定字符進(jìn)行填充,第三個(gè)參數(shù)表示字符編碼,默認(rèn)為utf8
let buf3 = Buffer.alloc(6, 'a', 'utf8');
console.log(buf3);

通過(guò)Buffer.allocUnsafe創(chuàng)建未初始化的Buffer,Buffer中的數(shù)據(jù)是未知的。

let buf = Buffer.allocUnsafe(6);
console.log(buf);

通過(guò)字節(jié)數(shù)組創(chuàng)建一個(gè)Buffer

let buf = Buffer.from([1, 2, 3, 4, 5]);
console.log(buf);

通過(guò)字符串創(chuàng)建一個(gè)Buffer,第二個(gè)參數(shù)表示字符編碼,一個(gè)中文用3個(gè)字節(jié)表示。

let buf = Buffer.from('世界你好', 'utf8');
console.log(buf);

五、Buffer的一些常用方法

通過(guò) fill() 以指定的數(shù)據(jù)填充Buffer

let buf = Buffer.alloc(12);
console.log(buf);
//參數(shù)一表示用來(lái)填充的值
//參數(shù)二表示開(kāi)始的偏移量
//參數(shù)三表示結(jié)束的偏移量
//參數(shù)四表示字符編碼
//偏移量的計(jì)算是左閉右開(kāi)的區(qū)間,[start, end)
buf.fill(1, 0, 2);
console.log(buf);
buf.fill(2, 2, 4);
console.log(buf);
buf.fill('A', 4, 6);
console.log(buf);

通過(guò) write() 向Buffer中寫(xiě)入數(shù)據(jù)

let buf = Buffer.alloc(12);
console.log(buf);
//參數(shù)一表示要寫(xiě)入的字符串
//參數(shù)二表示寫(xiě)入的偏移量
//參數(shù)三表示寫(xiě)入的字節(jié)數(shù)
//參數(shù)四表示字符編碼
buf.write('世界', 0, 3);
console.log(buf);
console.log(buf.toString());
buf.write('世界', 3, 6);
console.log(buf);
console.log(buf.toString());

通過(guò) writeInt8() 寫(xiě)入一個(gè)8位的整數(shù),注意該整數(shù)是帶符號(hào)的。

let buf = Buffer.alloc(12);
console.log(buf);
buf.writeInt8(1, 0);
buf.writeInt8(2, 1);
buf.writeInt8(3, 2);
//注意,8位的整數(shù),如果帶符號(hào),區(qū)間在 -128 到 127 之間
buf.writeInt8(127, 3);
console.log(buf);

方法中還有一些writeInt16BE(),writeInt32BE(),writeInt16LE(),writeInt32LE()的方法。

因?yàn)椴煌腃PU架構(gòu),有不同的字節(jié)序,字節(jié)序是指數(shù)字在內(nèi)存中保存的順序。

以 BE 結(jié)尾的,表示 Big Endian ,將高位存儲(chǔ)在起始位置。

以 LE 結(jié)尾的,表示 Little Endian,將低位存儲(chǔ)在起始位置。

let buf = Buffer.alloc(6);
//將高位存儲(chǔ)在起始位置
buf.writeInt16BE('256', 0); // [01 00 00 00 00 00]
console.log(buf);
//讀取要與寫(xiě)入的方法一致,不然數(shù)據(jù)會(huì)錯(cuò)亂。
console.log(buf.readInt16BE(0));
let buf2 = Buffer.alloc(6);
//將低位存儲(chǔ)在起始位置
buf2.writeInt16LE('256', 0); // [00 01 00 00 00 00]
console.log(buf2);
//讀取要與寫(xiě)入的方法一致,不然數(shù)據(jù)會(huì)錯(cuò)亂。
console.log(buf.readInt16LE(0));

通過(guò) toString() 方法,將Buffer解碼成字符串。

let buf = Buffer.alloc(12);
buf.write('世', 0, 3);
buf.write('界', 3, 3);
buf.write('你', 6, 3);
buf.write('好', 9, 3);
console.log(buf);
console.log(buf.toString());

通過(guò) slice() 創(chuàng)建一個(gè)新的Buffer切片,但是內(nèi)存的指向與原Buffer仍然是同一塊內(nèi)存。

let buf = Buffer.alloc(12, 6);
console.log(buf);
//參數(shù)一表示開(kāi)始切片偏移量
//參數(shù)二表示結(jié)束切片偏移量
let buf2 = buf.slice(0, 3);
buf2.fill(9);
console.log(buf);

通過(guò) copy() 拷貝一個(gè)Buffer的數(shù)據(jù)到另一個(gè)Buffer

let t_buf = Buffer.alloc(12);
let s_buf = Buffer.alloc(6);
s_buf.write('世界', 0);
console.log(s_buf.toString());
//參數(shù)一表示,拷貝進(jìn)的Buffer
//參數(shù)二表示,拷貝進(jìn)Buffer的開(kāi)始偏移量
//參數(shù)三表示,源Buffer的開(kāi)始拷貝偏移量
//參數(shù)四表示,源Buffer的結(jié)束拷貝偏移量
s_buf.copy(t_buf, 0, 0, 6);
console.log(t_buf.toString());

通過(guò) Buffer.concat() 可以合并多個(gè)Buffer,返回一個(gè)新Buffer

let buf1 = Buffer.alloc(6);
buf1.write('hello,');
let buf2 = Buffer.alloc(6);
buf2.write('世界');
let buf3 = Buffer.concat([buf1, buf2]);
console.log(buf3.toString());
//如果合并后的Buffer字節(jié)數(shù)大于設(shè)置的值,則會(huì)截?cái)?
let buf4 = Buffer.concat([buf1, buf2], 9);
console.log(buf4.toString());

判斷是否為一個(gè)Buffer

console.log(Buffer.isBuffer({'name': 'test'}));
console.log(Buffer.isBuffer(Buffer.from('test')));

通過(guò) Buffer.byteLength() 獲取字符串字節(jié)長(zhǎng)度

console.log(Buffer.byteLength('你好,世界'));

以上就是node.js中Buffer緩沖器的原理是什么,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI