微信小程序Node.js? Buffer:
JavaScript語言自身只有字符串?dāng)?shù)據(jù)類型,沒有二進(jìn)制數(shù)據(jù)類型本昏。
但在處理像TCP流或文件流時供汛,必須使用到二進(jìn)制數(shù)據(jù)。因此在Node.js中,定義了一個 Buffer 類怔昨,該類用來創(chuàng)建一個專門存放二進(jìn)制數(shù)據(jù)的緩存區(qū)雀久。
在node.js中,Buffer 類是隨 Node 內(nèi)核一起發(fā)布的核心庫朱监。Buffer 庫為 Node.js帶來了一種存儲原始數(shù)據(jù)的方法岸啡,可以讓 Node.js 處理二進(jìn)制數(shù)據(jù)原叮,每當(dāng)需要在 Node.js 中處理I/O操作中移動的數(shù)據(jù)時赫编,就有可能使用 Buffer 庫。原始數(shù)據(jù)存儲在 Buffer 類的實(shí)例中奋隶。一個 Buffer 類似于一個整數(shù)數(shù)組擂送,但它對應(yīng)于 V8 堆內(nèi)存之外的一塊原始內(nèi)存。
創(chuàng)建Buffer
1.長度為10的實(shí)例varbuf =newBuffer(10)2.通過給定的數(shù)組創(chuàng)建varbuf =newBuffer([10,20,30,40,50])3.通過字符串創(chuàng)建varbuf =newBuffer("www.csdn.net","utf-8")utf-8是默認(rèn)的編碼方式支持以下編碼:"ascii","utf8","utf16le","ucs2","base64"和"hex"唯欣。
寫入緩存區(qū).write()
varbuf =newBuffer(200)varlen= buf.write("www.csdn.net")console.log("寫入字節(jié)數(shù):"+len)
string - 寫入緩沖區(qū)的字符串嘹吨。
offset - 緩沖區(qū)開始寫入的索引值,默認(rèn)為 0 境氢。
length - 寫入的字節(jié)數(shù)蟀拷,默認(rèn)為 buffer.length
encoding - 使用的編碼。默認(rèn)為 ‘utf8’ 萍聊。
緩存區(qū)讀取.toString()
buf = new Buffer(26);for (vari =0; i < 26 ; i++) {buf[i] = i +97;}console.log(buf.toString('ascii'));? ? ? // 輸出: abcdefghijklmnopqrstuvwxyzconsole.log(buf.toString('ascii',0,5));? // 輸出: abcdeconsole.log(buf.toString('utf8',0,5));? ? // 輸出: abcdeconsole.log(buf.toString(undefined,0,5)); // 使用 'utf8' 編碼, 并輸出: abcde
encoding - 使用的編碼问芬。默認(rèn)為 ‘utf8’ 。
start - 指定開始讀取的索引位置寿桨,默認(rèn)為 0此衅。
end - 結(jié)束位置,默認(rèn)為緩沖區(qū)的末尾亭螟。
Buffer轉(zhuǎn)JSON
varbuf =newBuffer('www.runoob.com');varjson = buf.toJSON(buf);console.log(json);
合并 Buffer.concat([,])
varbuf =newBuffer("北京")varbuf1 =newBuffer("上海")varbuf2 = Buffer.concat([buf,buf1],12)console.log(buf2.toString())
list用于合并的 Buffer 對象數(shù)組列表挡鞍。
totalLength指定合并后Buffer對象的總長度。
比較 .compare(otherBuffer)
在 Node.js v0.12.2 版本引入
varbuffer1 =newBuffer("AVCX")varbuffer2 =newBuffer("ACVV")varresult = buffer1.compare(buffer2)if(result <0) {console.log(buffer1 +" 在 "+ buffer2 +"之前");}elseif(result ==0){console.log(buffer1 +" 與 "+ buffer2 +"相同");}else{console.log(buffer1 +" 在 "+ buffer2 +"之后");}
拷貝 .compare(buffer2)
buf.copy(targetBuffer[, targetStart[,sourceStart[,sourceEnd]]])
targetBuffer - 要拷貝的 Buffer 對象预烙。
targetStart - 數(shù)字, 可選, 默認(rèn): 0
sourceStart - 數(shù)字, 可選, 默認(rèn): 0
sourceEnd - 數(shù)字, 可選, 默認(rèn): buffer.length
varbuf1 =newBuffer("beiJing")varbuf2 =newBuffer(8)buf1.copy(buf2)console.log("buf2 content:"+buf2.toString())
剪裁 .slice(buffer2)
buf.slice([start[, end]])
start - 數(shù)字, 可選, 默認(rèn): 0
end - 數(shù)字, 可選, 默認(rèn): buffer.length
返回值
返回一個新的緩沖區(qū)墨微,它和舊緩沖區(qū)指向同一塊內(nèi)存,但是從索引 start 到 end 的位置剪切。
varbuf1 =newBuffer("beiJing")varbuf2 = buf1.slice(0,8)console.log("buf2 content:"+buf2)// beiJing
長度 .length
buf.length;
//返回這個 buffer 的 bytes 數(shù)势就。注意這未必是 buffer 里面內(nèi)容的大小莉给。length 是 buffer 對象所分配的內(nèi)存數(shù),它不會隨著這個 buffer 對象內(nèi)容的改變而改變炼蹦。