欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年07月06日 14:27:41   作者:xiaochun365  
這篇文章主要介紹了 微信小程序 Buffer緩沖區(qū)的詳解的相關(guān)資料,需要的朋友可以參考下

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

JavaScript 語(yǔ)言自身只有字符串?dāng)?shù)據(jù)類型,沒(méi)有二進(jìn)制數(shù)據(jù)類型。

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

在 node.js 中,Buffer 類是隨 Node 內(nèi)核一起發(fā)布的核心庫(kù)。Buffer 庫(kù)為 Node.js 帶來(lái)了一種存儲(chǔ)原始數(shù)據(jù)的方法,可以讓 Node.js 處理二進(jìn)制數(shù)據(jù),每當(dāng)需要在 Node.js 中處理I/O操作中移動(dòng)的數(shù)據(jù)時(shí),就有可能使用 Buffer 庫(kù)。原始數(shù)據(jù)存儲(chǔ)在 Buffer 類的實(shí)例中。一個(gè) Buffer 類似于一個(gè)整數(shù)數(shù)組,但它對(duì)應(yīng)于 V8 堆內(nèi)存之外的一塊原始內(nèi)存。

創(chuàng)建Buffer

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

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

var buf = new Buffer(200)
var len = buf.write("www.csdn.net")
console.log("寫入字節(jié)數(shù):" + len)
  • string - 寫入緩沖區(qū)的字符串。
  • offset - 緩沖區(qū)開(kāi)始寫入的索引值,默認(rèn)為 0 。
  • length - 寫入的字節(jié)數(shù),默認(rèn)為 buffer.length
  • encoding - 使用的編碼。默認(rèn)為 ‘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 - 使用的編碼。默認(rèn)為 ‘utf8' 。
  2. start - 指定開(kāi)始讀取的索引位置,默認(rèn)為 0。
  3. end - 結(jié)束位置,默認(rèn)為緩沖區(qū)的末尾。

Buffer轉(zhuǎn)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 對(duì)象數(shù)組列表。
  • totalLength指定合并后Buffer對(duì)象的總長(zhǎng)度。

比較 .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 對(duì)象。
  2. targetStart - 數(shù)字, 可選, 默認(rèn): 0
  3. sourceStart - 數(shù)字, 可選, 默認(rèn): 0
  4. sourceEnd - 數(shù)字, 可選, 默認(rèn): 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 - 數(shù)字, 可選, 默認(rèn): 0
  2. end - 數(shù)字, 可選, 默認(rèn): buffer.length

返回值

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

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

長(zhǎng)度 .length

buf.length;

//返回這個(gè) buffer 的 bytes 數(shù)。注意這未必是 buffer 里面內(nèi)容的大小。length 是 buffer 對(duì)象所分配的內(nèi)存數(shù),它不會(huì)隨著這個(gè) buffer 對(duì)象內(nèi)容的改變而改變。

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

相關(guān)文章

  • 微信小程序 獲取當(dāng)前地理位置和經(jīng)緯度實(shí)例代碼

    微信小程序 獲取當(dāng)前地理位置和經(jīng)緯度實(shí)例代碼

    這篇文章主要介紹了微信小程序 獲取當(dāng)前地理位置和經(jīng)緯度實(shí)例代碼的相關(guān)資料,這里附有實(shí)例代碼,及實(shí)現(xiàn)效果圖,需要的朋友可以參考下
    2016-12-12
  • 微信小程序 Image API實(shí)例詳解

    微信小程序 Image API實(shí)例詳解

    這篇文章主要介紹了微信小程序 Image API實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • JavaScript的單線程和異步詳細(xì)

    JavaScript的單線程和異步詳細(xì)

    這篇文章要給大家分享的是JavaScript的單線程和異步,其實(shí)單線程和異步確實(shí)不能同時(shí)成為一個(gè)語(yǔ)言的特性,js選擇了成為單線程的語(yǔ)言,所以它本身不可能是異步的,但js宿主環(huán)境是多線程,宿主環(huán)境通過(guò)某種方式使js具備了異步屬性,下面就來(lái)具體介紹,需要的朋友可以參考一下
    2021-10-10
  • JavaScript中的設(shè)計(jì)模式 單例模式

    JavaScript中的設(shè)計(jì)模式 單例模式

    這篇文章主要給大家介紹的是JavaScript中的單例模式,設(shè)計(jì)模式代表了最佳的實(shí)踐,通常被有經(jīng)驗(yàn)的面向?qū)ο蟮能浖_(kāi)發(fā)人員所采用。設(shè)計(jì)模式是軟件開(kāi)發(fā)人員在軟件開(kāi)發(fā)過(guò)程中面臨的一般問(wèn)題的解決方案,需要的朋友可以參考一下
    2021-09-09
  • 微信小程序promsie.all和promise順序執(zhí)行

    微信小程序promsie.all和promise順序執(zhí)行

    這篇文章主要介紹了微信小程序promsie.all和promise順序執(zhí)行的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下
    2017-10-10
  • 微信小程序 radio單選框組件詳解及實(shí)例代碼

    微信小程序 radio單選框組件詳解及實(shí)例代碼

    這篇文章主要介紹了微信小程序 radio單選框組件詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • Intl對(duì)象DateTimeFormat?ListFormat?RelativeTimeFormat使用講解

    Intl對(duì)象DateTimeFormat?ListFormat?RelativeTimeFormat使用講解

    這篇文章主要為大家介紹了Intl對(duì)象DateTimeFormat?ListFormat?RelativeTimeFormat使用講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • JS前端輕量fabric.js系列物體基類

    JS前端輕量fabric.js系列物體基類

    這篇文章主要為大家介紹了實(shí)現(xiàn)JS前端輕量fabric.js系列物體基類示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 微信小程序頁(yè)面間通信的5種方式

    微信小程序頁(yè)面間通信的5種方式

    這篇文章主要介紹了微信小程序頁(yè)面間通信的5種方式,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 微信小程序 input表單與redio及下拉列表的使用實(shí)例

    微信小程序 input表單與redio及下拉列表的使用實(shí)例

    這篇文章主要介紹了微信小程序 input表單與redio及下拉列表的使用實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下
    2017-09-09

最新評(píng)論