微信小程序Node.js? Buffer:
JavaScript語言自身只有字符串?dāng)?shù)據(jù)類型,沒有二進(jìn)制數(shù)據(jù)類型。
但在處理像TCP流或文件流時(shí),必須使用到二進(jìn)制數(shù)據(jù)。因此在Node.js中,定義了一個(gè) Buffer 類,該類用來創(chuàng)建一個(gè)專門存放二進(jìn)制數(shù)據(jù)的緩存區(qū)。
在node.js中,Buffer 類是隨 Node 內(nèi)核一起發(fā)布的核心庫。Buffer 庫為 Node.js帶來了一種存儲(chǔ)原始數(shù)據(jù)的方法,可以讓 Node.js 處理二進(jìn)制數(shù)據(jù),每當(dāng)需要在 Node.js 中處理I/O操作中移動(dòng)的數(shù)據(jù)時(shí),就有可能使用 Buffer 庫。原始數(shù)據(jù)存儲(chǔ)在 Buffer 類的實(shí)例中。一個(gè) Buffer 類似于一個(gè)整數(shù)數(shù)組,但它對(duì)應(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 對(duì)象數(shù)組列表。
totalLength指定合并后Buffer對(duì)象的總長度。
比較 .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 對(duì)象。
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
返回值
返回一個(gè)新的緩沖區(qū),它和舊緩沖區(qū)指向同一塊內(nèi)存,但是從索引 start 到 end 的位置剪切。
varbuf1 =newBuffer("beiJing")varbuf2 = buf1.slice(0,8)console.log("buf2 content:"+buf2)// beiJing
長度 .length
buf.length;
//返回這個(gè) buffer 的 bytes 數(shù)。注意這未必是 buffer 里面內(nèi)容的大小。length 是 buffer 對(duì)象所分配的內(nèi)存數(shù),它不會(huì)隨著這個(gè) buffer 對(duì)象內(nèi)容的改變而改變。