javaScript 語言自身只有字符串數據類型,沒有二進制數據類型。
但在處理像TCP流或文件流時,必須使用到二進制數據。因此在 Node.js中,定義了一個 Buffer 類,該類用來創建一個專門存放二進制數據的緩存區。
在 Node.js 中,Buffer 類是隨 Node 內核一起發布的核心庫。Buffer 庫為 Node.js 帶來了一種存儲原始數據的方法,可以讓 Node.js 處理二進制數據,每當需要在 Node.js 中處理I/O操作中移動的數據時,就有可能使用 Buffer 庫。原始數據存儲在 Buffer 類的實例中。一個 Buffer 類似于一個整數數組,但它對應于 V8 堆內存之外的一塊原始內存。
Node Buffer 類可以通過多種方式來創建。
創建長度為 10 字節的 Buffer 實例:
var buf = new Buffer(10);
通過給定的數組創建 Buffer 實例:
var buf = new Buffer([10, 20, 30, 40, 50]);
通過一個字符串來創建 Buffer 實例:
var buf = new Buffer(“www.runoob.com”, “utf-8”);
utf-8 是默認的編碼方式,此外它同樣支持以下編碼:”ascii”, “utf8”, “utf16le”, “ucs2”, “base64” 和 “hex”。
寫入 Node 緩沖區的語法如下所示:
buf.write(string[,offset[,length]][,encoding])
string- 寫入緩沖區的字符串。
offset- 緩沖區開始寫入的索引值,默認為 0 。
length- 寫入的字節數,默認為 buffer.length
encoding- 使用的編碼。默認為 ‘utf8’ 。
返回實際寫入的大小。如果 buffer 空間不足, 則只會寫入部分字符串。
node E:/study/node/main1.js
讀取 Node 緩沖區數據的語法如下所示:
buf.toString([encoding[,start[,end]]])
encoding- 使用的編碼。默認為 ‘utf8’ 。
start- 指定開始讀取的索引位置,默認為 0。
end- 結束位置,默認為緩沖區的末尾。
解碼緩沖區數據并使用指定的編碼返回字符串。
node E:/study/node/main1.js
將 Node Buffer 轉換為 JSON 對象的函數語法格式如下:buf.toJSON()
返回 JSON 對象。
Node 緩沖區合并的語法如下所示:Buffer.concat(list[,totalLength])
list- 用于合并的 Buffer 對象數組列表。
totalLength- 指定合并后Buffer對象的總長度。
返回一個多個成員合并的新 Buffer 對象。
Node Buffer 比較的函數語法如下所示, 該方法在 Node.js v0.12.2 版本引入:buf.compare(otherBuffer);
otherBuffer- 與buf對象比較的另外一個 Buffer 對象。
返回一個數字,表示buf在otherBuffer之前,之后或相同。
Node 緩沖區拷貝語法如下所示:buf.copy(targetBuffer[,targetStart[,sourceStart[,sourceEnd]]])
targetBuffer- 要拷貝的 Buffer 對象。
targetStart- 數字, 可選, 默認: 0
sourceStart- 數字, 可選, 默認: 0
sourceEnd- 數字, 可選, 默認: buffer.length
Node 緩沖區裁剪語法如下所示:buf.slice([start[,end]])
start- 數字, 可選, 默認: 0
end- 數字, 可選, 默認: buffer.length
返回一個新的緩沖區,它和舊緩沖區指向同一塊內存,但是從索引 start 到 end 的位置剪切。
Node 緩沖區長度計算語法如下所示:buf.length;
返回 Buffer 對象所占據的內存長度。
以下列出了 Node.js Buffer 模塊常用的方法
參考資料
新聞熱點
疑難解答