久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      深入了解Node.js中的 Buffer(緩沖區(qū))

      本篇文章帶大家深入了解下Node.js中的 Buffer(緩沖區(qū)),介紹一下創(chuàng)建 Buffer 類的多種方式、寫入緩沖區(qū)的方法等,希望對大家有所幫助!

      深入了解Node.js中的 Buffer(緩沖區(qū))

      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 帶來了一種存儲原始數(shù)據(jù)的方法,可以讓 Node.js 處理二進(jìn)制數(shù)據(jù),每當(dāng)需要在 Node.js 中處理 I/O 操作中移動(dòng)的數(shù)據(jù)時(shí),就有可能使用 Buffer 庫。

      原始數(shù)據(jù)存儲在 Buffer 類的實(shí)例中。

      一個(gè) Buffer 類似于一個(gè)整數(shù)數(shù)組,但它對應(yīng)于 V8 堆內(nèi)存之外的一塊原始內(nèi)存。

      創(chuàng)建 Buffer 類

      Node Buffer 類可以通過多種方式來創(chuàng)建。

      方法 1

      創(chuàng)建長度為 10 字節(jié)的 Buffer 實(shí)例:

      var buf = new Buffer(10);

      方法 2

      通過給定的數(shù)組創(chuàng)建 Buffer 實(shí)例:

      var buf = new Buffer([10, 20, 30, 40, 50]);

      方法 3

      通過一個(gè)字符串來創(chuàng)建 Buffer 實(shí)例:

      var buf = new Buffer("bianchengsanmei", "utf-8");

      utf-8 是默認(rèn)的編碼方式,此外它同樣支持以下編碼:"ascii", "utf8", "utf16le", "ucs2", "base64" 和 "hex"。

      寫入緩沖區(qū)

      語法

      寫入 Node 緩沖區(qū)的語法如下所示:

      buf.write(string[, offset[, length]][, encoding])

      參數(shù)

      參數(shù)描述如下:

      • string – 寫入緩沖區(qū)的字符串。
      • offset – 緩沖區(qū)開始寫入的索引值,默認(rèn)為 0 。
      • length – 寫入的字節(jié)數(shù),默認(rèn)為 buffer.length
      • encoding – 使用的編碼。默認(rèn)為 'utf8' 。

      返回值

      返回實(shí)際寫入的大小。如果 buffer 空間不足, 則只會寫入部分字符串。
      實(shí)例

      buf = new Buffer(256); len = buf.write("bi"); len = buf.write("bianchengsanmei");  console.log("寫入字節(jié)數(shù) : "+  len);

      執(zhí)行以上代碼,輸出結(jié)果為:

      $node main.js 寫入字節(jié)數(shù) : 15復(fù)制代碼

      從緩沖區(qū)讀取數(shù)據(jù)

      語法

      讀取 Node 緩沖區(qū)數(shù)據(jù)的語法如下所示:

      buf.toString([encoding[,start[,end]]])

      參數(shù)

      參數(shù)描述如下:

      • encoding – 使用的編碼。默認(rèn)為 'utf8' 。

      • start – 指定開始讀取的索引位置,默認(rèn)為 0。

      • end – 結(jié)束位置,默認(rèn)為緩沖區(qū)的末尾。

      返回值

      解碼緩沖區(qū)數(shù)據(jù)并使用指定的編碼返回字符串。

      實(shí)例

      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

      執(zhí)行以上代碼,輸出結(jié)果為:

      $ node main.js abcdefghijklmnopqrstuvwxyz abcde abcde abcde

      將 Buffer 轉(zhuǎn)換為 JSON 對象

      語法

      將 Node Buffer 轉(zhuǎn)換為 JSON 對象的函數(shù)語法格式如下:

      buf.toJSON()

      返回值

      返回 JSON 對象。

      實(shí)例

      var buf = new Buffer('bianchengsanmei'); var json = buf.toJSON(buf);   console.log(json);

      執(zhí)行以上代碼,輸出結(jié)果為:

      {   type: 'Buffer',   data: [      98, 105, 97, 110, 99, 104, 101, 110, 103, 115, 97, 110, 109, 101, 105   ] }

      緩沖區(qū)合并

      語法

      Node 緩沖區(qū)合并的語法如下所示:

      Buffer.concat(list[, totalLength])

      參數(shù)

      參數(shù)描述如下:

      • list – 用于合并的 Buffer 對象數(shù)組列表。
      • totalLength – 指定合并后 Buffer 對象的總長度。

      返回值

      返回一個(gè)多個(gè)成員合并的新 Buffer 對象。

      實(shí)例

      var buffer1 = new Buffer('編程三昧 '); var buffer2 = new Buffer('bi'); var buffer2 = new Buffer('bianchengsanmei'); var buffer3 = Buffer.concat([buffer1,buffer2]); console.log("buffer3 內(nèi)容: " + buffer3.toString());

      執(zhí)行以上代碼,輸出結(jié)果為:

      buffer3 內(nèi)容: 編程三昧 bianchengsanmei

      緩沖區(qū)比較

      語法

      Node Buffer 比較的函數(shù)語法如下所示, 該方法在 Node.js v0.12.2 版本引入:

      buf.compare(otherBuffer);

      參數(shù)

      參數(shù)描述如下:

      • otherBuffer – 與 buf 對象比較的另外一個(gè) Buffer 對象。

      返回值

      返回一個(gè)數(shù)字,表示 bufotherBuffer 之前,之后或相同。

      實(shí)例

      var buffer1 = new Buffer('ABC'); var buffer2 = new Buffer('ABCD'); 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 + "之后"); }

      執(zhí)行以上代碼,輸出結(jié)果為:

      ABC在ABCD之前

      拷貝緩沖區(qū)

      語法

      Node 緩沖區(qū)拷貝語法如下所示:

      buf.copy(target[, targetStart[, sourceStart[, sourceEnd]]])

      參數(shù)

      參數(shù)描述如下:

      • targetBuffer – 要拷貝的 Buffer 對象。
      • targetStart – 數(shù)字, 可選, 默認(rèn): 0
      • sourceStart – 數(shù)字, 可選, 默認(rèn): 0
      • sourceEnd – 數(shù)字, 可選, 默認(rèn): buffer.length

      返回值

      沒有返回值。

      實(shí)例

      var buffer1 = new Buffer('ABC'); // 拷貝一個(gè)緩沖區(qū) var buffer2 = new Buffer(3); buffer1.copy(buffer2); console.log("buffer2 content: " + buffer2.toString());

      執(zhí)行以上代碼,輸出結(jié)果為:

      buffer2 content: ABC

      緩沖區(qū)裁剪

      Node 緩沖區(qū)裁剪語法如下所示:

      buf.slice([start[, end]])

      參數(shù)

      參數(shù)描述如下:

      • start – 數(shù)字, 可選, 默認(rèn): 0
      • end – 數(shù)字, 可選, 默認(rèn): buffer.length

      返回值

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

      實(shí)例

      var buffer1 = new Buffer('youj'); // 剪切緩沖區(qū) var buffer2 = buffer1.slice(0,2); console.log("buffer2 content: " + buffer2.toString());

      執(zhí)行以上代碼,輸出結(jié)果為:

      buffer2 content: yo

      緩沖區(qū)長度

      語法 Node 緩沖區(qū)長度計(jì)算語法如下所示:

      buf.length;

      返回值

      返回 Buffer 對象所占據(jù)的內(nèi)存長度。

      實(shí)例

      var buffer = new Buffer('bianchengsanmei'); //  緩沖區(qū)長度 console.log("buffer length: " + buffer.length);

      執(zhí)行以上代碼,輸出結(jié)果為:

      buffer length: 15

      ~

      ~本文完,感謝閱讀!

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號