溫馨提示×

溫馨提示×

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

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

微信小程序 Buffer緩沖區(qū)的詳解

發(fā)布時間:2020-09-20 09:30:07 來源:腳本之家 閱讀:1003 作者:xiaochun365 欄目:web開發(fā)

 微信小程序 Buffer緩沖區(qū)的詳解

JavaScript 語言自身只有字符串數據類型,沒有二進制數據類型。

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

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

創(chuàng)建Buffer

1.長度為10的實例
var buf = new Buffer(10)
2.通過給定的數組創(chuàng)建
var buf = new Buffer([10,20,30,40,50])
3.通過字符串創(chuàng)建
var buf = new Buffer("www.csdn.net","utf-8")
utf-8 是默認的編碼方式
支持以下編碼:"ascii", "utf8", "utf16le", "ucs2", "base64" 和 "hex"。

寫入緩存區(qū).write()

var buf = new Buffer(200)
var len = buf.write("www.csdn.net")
console.log("寫入字節(jié)數:" + len)
  • string - 寫入緩沖區(qū)的字符串。
  • offset - 緩沖區(qū)開始寫入的索引值,默認為 0 。
  • length - 寫入的字節(jié)數,默認為 buffer.length
  • encoding - 使用的編碼。默認為 ‘utf8' 。

緩存區(qū)讀取.toString()

buf = new Buffer(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. encoding - 使用的編碼。默認為 ‘utf8' 。
  2. start - 指定開始讀取的索引位置,默認為 0。
  3. end - 結束位置,默認為緩沖區(qū)的末尾。

Buffer轉JSON

var buf = new Buffer('www.runoob.com');
var json = buf.toJSON(buf);
console.log(json);

合并 Buffer.concat([,])

var buf = new Buffer("北京")
var buf1 = new Buffer("上海")
var buf2 = Buffer.concat([buf,buf1],12)
console.log(buf2.toString())
  • list用于合并的 Buffer 對象數組列表。
  • totalLength指定合并后Buffer對象的總長度。

比較 .compare(otherBuffer)

在 Node.js v0.12.2 版本引入

var buffer1 = new Buffer("AVCX")
var buffer2 = new Buffer("ACVV")

var result = buffer1.compare(buffer2)

if(result < 0) {
  console.log(buffer1 + " 在 " + buffer2 + "之前");
}else if(result == 0){
  console.log(buffer1 + " 與 " + buffer2 + "相同");
}else {
  console.log(buffer1 + " 在 " + buffer2 + "之后");
}

拷貝 .compare(buffer2)

buf.copy(targetBuffer[, targetStart[, sourceStart[, sourceEnd]]])
  1. targetBuffer - 要拷貝的 Buffer 對象。
  2. targetStart - 數字, 可選, 默認: 0
  3. sourceStart - 數字, 可選, 默認: 0
  4. sourceEnd - 數字, 可選, 默認: buffer.length
var buf1 = new Buffer("beiJing")
var buf2 = new Buffer(8)
buf1.copy(buf2)
console.log("buf2 content:"+buf2.toString())

剪裁 .slice(buffer2)

buf.slice([start[, end]])
  1. start - 數字, 可選, 默認: 0
  2. end - 數字, 可選, 默認: buffer.length

返回值

返回一個新的緩沖區(qū),它和舊緩沖區(qū)指向同一塊內存,但是從索引 start 到 end 的位置剪切。

var buf1 = new Buffer("beiJing")
var buf2 = buf1.slice(0,8)
console.log("buf2 content:"+buf2)
// beiJing

長度 .length

buf.length;

//返回這個 buffer 的 bytes 數。注意這未必是 buffer 里面內容的大小。length 是 buffer 對象所分配的內存數,它不會隨著這個 buffer 對象內容的改變而改變。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

向AI問一下細節(jié)

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

AI