溫馨提示×

溫馨提示×

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

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

Node.js?Buffer模塊的方法以及示例分析

發(fā)布時間:2022-01-06 13:09:34 來源:億速云 閱讀:134 作者:柒染 欄目:開發(fā)技術(shù)

Node.js Buffer模塊的方法以及示例分析,針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

二進制流是大量的二進制數(shù)據(jù)的集合。由于通常情況下二進制流的大小挺大的,因此二進制流一般不會一起運送,而會在運輸前切分成小塊然后逐一發(fā)送。

當(dāng)數(shù)據(jù)處理單元暫時不再接收其他數(shù)據(jù)流時,剩余的數(shù)據(jù)將會被保留在緩存中,直到數(shù)據(jù)處理單元準備好接收更多數(shù)據(jù)為止。

Node.js 服務(wù)器一般需要在文件系統(tǒng)中進行讀寫,而文件在存儲層面而言其實都是二進制流。除此之外,Node.js 還能與 TCP 流一起使用,讓 TCP 流在不可靠的互聯(lián)網(wǎng)絡(luò)上提供可靠的端到端字節(jié)流保障通信。

發(fā)送給接收者的數(shù)據(jù)流會被緩沖,直到接收者準備接收更多要處理的數(shù)據(jù)為止。這就是 Node.js 處理臨時數(shù)據(jù)部分的工作內(nèi)容 ,在 V8 引擎外部管理和存儲二進制數(shù)據(jù)。

讓我們一起深入緩沖區(qū)(Buffer)的各種使用方法,了解更多有關(guān)它們的信息以及一起學(xué)習(xí)如何在 Node.js 程序中使用它們吧。

Node.js Buffer 的方法

Node.js 緩沖模塊的最大優(yōu)勢,其實就是它是內(nèi)置于 Node.js 中的,因此我們可以在任何我們想要使用它的地方使用它。

讓我們一起瀏覽一些重要的 Node.js 緩沖模塊的方法吧。

Buffer.alloc()

此方法將創(chuàng)建一個新的緩沖區(qū),但是分配的大小不是固定的。當(dāng)我們調(diào)用此方法時,可以自行分配大?。ㄒ宰止?jié)為單位)。

const buf = Buffer.alloc(6)  // 這會創(chuàng)建一個 6 字節(jié)的緩沖區(qū)
console.log(buf) // <Buffer 00 00 00 00 00 00>

Buffer.byteLength()

如果我們想要獲取緩沖區(qū)的長度,我們只需調(diào)用 Buffer.byteLength() 就行了。

var buf = Buffer.alloc(10)
var buffLen = Buffer.byteLength(buf) // 檢查緩沖區(qū)長度
 
console.log(buffLen) // 10

Buffer.compare()

通過使用 Buffer.compare() 我們可以比較兩個緩沖區(qū),此方法的返回值是 -1,0,1 中的一個。

譯者注:buf.compare(otherBuffer); 這一句調(diào)用會返回一個數(shù)字 -1,0,1,分別對應(yīng) buf 在 otherBuffer 之前,之后或相同。

var buf1 = Buffer.from('Harsh')
var buf2 = Buffer.from('Harsg')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 這會打印 0
 
var buf1 = Buffer.from('a')
var buf2 = Buffer.from('b')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 這會打印 -1
 
 
var buf1 = Buffer.from('b')
var buf2 = Buffer.from('a')
var a = Buffer.compare(buf1, buf2)
console.log(a) // 這會打印 1

Buffer.concat()

顧名思義,我們可以使用此函數(shù)連接兩個緩沖區(qū)。當(dāng)然,就像字符串一樣,我們也可以連接兩個以上的緩沖區(qū)。

var buffer1 = Buffer.from('x')
var buffer2 = Buffer.from('y')
var buffer3 = Buffer.from('z')
var arr = [buffer1, buffer2, buffer3]
 
console.log(arr)
/* buffer, !concat [ <Buffer 78>, <Buffer 79>, <Buffer 7a> ] */
 
// 通過 Buffer.concat 方法連接兩個緩沖區(qū)
var buf = Buffer.concat(arr)
 
console.log(buf)
// <Buffer 78 79 7a> concat successful

Buffer.entries()

Buffer.entries() 會用這一緩沖區(qū)的內(nèi)容創(chuàng)建并返回一個 [index, byte] 形式的迭代器。

var buf = Buffer.from('xyz')
 
for (a of buf.entries()) {
    console.log(a)
    /* 這個會在控制臺輸出一個有緩沖區(qū)位置與內(nèi)容的字節(jié)的數(shù)組 [ 0, 120 ][ 1, 121 ][ 2, 122 ] */
}

Buffer.fill()

我們可以使用 Buffer.fill() 這個函數(shù)將數(shù)據(jù)插入或填充到緩沖區(qū)中。更多信息請參見下文。

const b = Buffer.alloc(10).fill('a')
 
console.log(b.toString())
// aaaaaaaaaa

Buffer.includes()

像字符串一樣,它將確認緩沖區(qū)是否具有該值。我們可以使用 Buffer.includes() 方法來實現(xiàn)這一點,給定方法根據(jù)搜索返回一個布爾值,即 true 或 false。

const buf = Buffer.from('this is a buffer')
console.log(buf.includes('this'))
// true
 
console.log(buf.includes(Buffer.from('a buffer example')))
// false

Buffer.isEncoding()

我們可能知道二進制文件必須進行編碼,那么如果我們要檢查數(shù)據(jù)類型是否支持字符編碼該怎么辦呢?我們可以使用 Buffer.isEncoding() 方法進行確認。如果支持,它將返回 true。

console.log(Buffer.isEncoding('hex'))
// true
 
console.log(Buffer.isEncoding('utf-8'))
// true
 
console.log(Buffer.isEncoding('utf/8'))
// false
 
console.log(Buffer.isEncoding('hey'))
// false

Buffer.slice()

buf.slice() 將用于使用緩沖區(qū)的選定元素創(chuàng)建一個新緩沖區(qū) &mdash;&mdash; 對緩沖區(qū)進行切割時,將創(chuàng)建一個新緩沖區(qū),其中包含要在新緩沖區(qū)切片中找到的項目的列表。

var a = Buffer.from('uvwxyz');
var b = a.slice(2, 5);
 
console.log(b.toString());
// wxy

Buffer.swapX()

Buffer.swapX() 用于交換緩沖區(qū)的字節(jié)順序。使用 Buffer.swapX() (此處 X 可以為 16, 32, 64)來交換 16 位,32 位和 64 位緩沖區(qū)對象的字節(jié)順序。

const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8])
console.log(buf1)
// <Buffer 01 02 03 04 05 06 07 08>
 
// 交換 16 位字節(jié)順序
buf1.swap16()
console.log(buf1)
// <Buffer 02 01 04 03 06 05 08 07>
 
// 交換 32 位字節(jié)順序
buf1.swap32()
console.log(buf1)
// <Buffer 03 04 01 02 07 08 05 06>
 
// 交換 64 位字節(jié)順序
buf1.swap64()
console.log(buf1)
// <Buffer 06 05 08 07 02 01 04 03>

Buffer.json()

它可以幫助我們從緩沖區(qū)創(chuàng)建 JSON 對象,而該方法將返回 JSON 緩沖區(qū)對象,

const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
 
console.log(buf.toJSON());
// {"type":"Buffer", data:[1, 2, 3, 4, 5, 6, 7, 8]}

關(guān)于Node.js Buffer模塊的方法以及示例分析問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細節(jié)

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

AI