亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

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

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

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

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

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

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

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

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

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

    創(chuàng)建 Buffer 類

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

    方法 1

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

    var buf = new Buffer(10);

    方法 2

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

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

    方法 3

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

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

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

    寫入緩沖區(qū)

    語法

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

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

    參數(shù)

    參數(shù)描述如下:

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

    返回值

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

    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復制代碼

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

    語法

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

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

    參數(shù)

    參數(shù)描述如下:

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

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

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

    返回值

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

    實例

    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 對象。

    實例

    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 對象的總長度。

    返回值

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

    實例

    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 對象比較的另外一個 Buffer 對象。

    返回值

    返回一個數(shù)字,表示 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 + "之后"); }

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

    ABC在ABCD之前

    拷貝緩沖區(qū)

    語法

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

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

    參數(shù)

    參數(shù)描述如下:

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

    返回值

    沒有返回值。

    實例

    var buffer1 = new Buffer('ABC'); // 拷貝一個緩沖區(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ù)字, 可選, 默認: 0
    • end – 數(shù)字, 可選, 默認: buffer.length

    返回值

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

    實例

    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ū)長度計算語法如下所示:

    buf.length;

    返回值

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

    實例

    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號