站長資訊網
        最全最豐富的資訊網站

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

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

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

        JavaScript 語言自身只有字符串數據類型,沒有二進制數據類型。

        但在處理像 TCP 流或文件流時,必須使用到二進制數據。因此在 Node.js 中,定義了一個 Buffer 類,該類用來創建一個專門存放二進制數據的緩存區。

        在 Node.js 中,Buffer 類是隨 Node 內核一起發布的核心庫。Buffer 庫為 Node.js 帶來了一種存儲原始數據的方法,可以讓 Node.js 處理二進制數據,每當需要在 Node.js 中處理 I/O 操作中移動的數據時,就有可能使用 Buffer 庫。

        原始數據存儲在 Buffer 類的實例中。

        一個 Buffer 類似于一個整數數組,但它對應于 V8 堆內存之外的一塊原始內存。

        創建 Buffer 類

        Node Buffer 類可以通過多種方式來創建。

        方法 1

        創建長度為 10 字節的 Buffer 實例:

        var buf = new Buffer(10);

        方法 2

        通過給定的數組創建 Buffer 實例:

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

        方法 3

        通過一個字符串來創建 Buffer 實例:

        var buf = new Buffer("bianchengsanmei", "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 空間不足, 則只會寫入部分字符串。
        實例

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

        執行以上代碼,輸出結果為:

        $node main.js 寫入字節數 : 15復制代碼

        從緩沖區讀取數據

        語法

        讀取 Node 緩沖區數據的語法如下所示:

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

        參數

        參數描述如下:

        • encoding – 使用的編碼。默認為 'utf8' 。

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

        • end – 結束位置,默認為緩沖區的末尾。

        返回值

        解碼緩沖區數據并使用指定的編碼返回字符串。

        實例

        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

        執行以上代碼,輸出結果為:

        $ node main.js abcdefghijklmnopqrstuvwxyz abcde abcde abcde

        將 Buffer 轉換為 JSON 對象

        語法

        將 Node Buffer 轉換為 JSON 對象的函數語法格式如下:

        buf.toJSON()

        返回值

        返回 JSON 對象。

        實例

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

        執行以上代碼,輸出結果為:

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

        緩沖區合并

        語法

        Node 緩沖區合并的語法如下所示:

        Buffer.concat(list[, totalLength])

        參數

        參數描述如下:

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

        返回值

        返回一個多個成員合并的新 Buffer 對象。

        實例

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

        執行以上代碼,輸出結果為:

        buffer3 內容: 編程三昧 bianchengsanmei

        緩沖區比較

        語法

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

        buf.compare(otherBuffer);

        參數

        參數描述如下:

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

        返回值

        返回一個數字,表示 bufotherBuffer 之前,之后或相同。

        實例

        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 + "之后"); }

        執行以上代碼,輸出結果為:

        ABC在ABCD之前

        拷貝緩沖區

        語法

        Node 緩沖區拷貝語法如下所示:

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

        參數

        參數描述如下:

        • targetBuffer – 要拷貝的 Buffer 對象。
        • targetStart – 數字, 可選, 默認: 0
        • sourceStart – 數字, 可選, 默認: 0
        • sourceEnd – 數字, 可選, 默認: buffer.length

        返回值

        沒有返回值。

        實例

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

        執行以上代碼,輸出結果為:

        buffer2 content: ABC

        緩沖區裁剪

        Node 緩沖區裁剪語法如下所示:

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

        參數

        參數描述如下:

        • start – 數字, 可選, 默認: 0
        • end – 數字, 可選, 默認: buffer.length

        返回值

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

        實例

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

        執行以上代碼,輸出結果為:

        buffer2 content: yo

        緩沖區長度

        語法 Node 緩沖區長度計算語法如下所示:

        buf.length;

        返回值

        返回 Buffer 對象所占據的內存長度。

        實例

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

        執行以上代碼,輸出結果為:

        buffer length: 15

        ~

        ~本文完,感謝閱讀!

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国内精品免费久久影院| 日韩精品电影一区亚洲| 国产一区二区精品尤物| 日本一卡精品视频免费| 免费视频成人国产精品网站| 欧美巨大黑人精品videos| 久久精品国产亚洲AV香蕉| 欧美精品亚洲精品日韩精品| 亚洲欧美精品伊人久久| 国产精品第12页| 亚洲国产精品无码av| 欧美国产精品va在线观看| 四虎精品影院4hutv四虎| 国产精品后入内射日本在线观看| 正在播放酒店精品少妇约| 青草青草久热精品视频在线观看| 国产91精品黄网在线观看| 精品久久久久久久久中文字幕| 欧美精品hdvideosex4k| 一本之道av不卡精品| 久久久久无码精品国产app| 国产精品极品| 国产精品福利在线观看免费不卡| 欧美精品1区2区| 国产精品一区二区久久| 国产成人精品手机在线观看| 日韩精品系列产品| 亚洲国产精品成人精品无码区 | 久久99精品国产麻豆| 亚洲精品乱码久久久久久蜜桃图片 | 国产精品成人在线| 91精品国产高清久久久久久io| 精品国产一区二区三区无码| 无码精品A∨在线观看中文| 欧美日韩人妻精品一区二区在线| 久久亚洲日韩精品一区二区三区| 亚洲精品无码午夜福利中文字幕| 伊人久久精品影院| 青青青国产精品一区二区| 国产午夜精品一区二区三区漫画 | 久久久久人妻一区精品性色av|