首頁 > 軟體

Node.js處理I/O資料之使用Buffer模組緩衝資料

2022-07-06 10:01:49

一、前傳

在之前做web時也經常用到js物件轉json和json轉js物件.既然是Node.js處理I/O資料,也把這個記下來。

Json轉Js物件:JSON.parse(jsonstr); //可以將json字串轉換成json物件
Js物件轉Json:JSON.stringify(jsonobj); //可以將json物件轉換成json對符串

var jsonStr='{"name":"cuiyanwei","sex":"男","blog":"http://www.cnblogs.com/5ishare/"}';
//json轉js物件
var jsObj=JSON.parse(jsonStr);
console.log(jsObj);
//js物件轉Json
var newJsonStr=JSON.stringify(jsObj);
console.log(newJsonStr);

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe Buffer.js
{ name: 'cuiyanwei',
  sex: '男',
  blog: 'http://www.cnblogs.com/5ishare/' }
{"name":"cuiyanwei","sex":"男","blog":"http://www.cnblogs.com/5ishare/"}

Process finished with exit code 0

二、Buffer模組緩衝資料

1.介紹

緩衝資料是由一系列大端或小端(這個要百度)格式位元組組成,比文字資料佔用較小空間.Buffer模組是全域性的,不需要使用require()來存取它。

緩衝資料被儲存在類似陣列的結構中,但被儲存在正常V8堆記憶體之外的原始記憶體分配區中,因此不能調整大小.

2.使用

在介紹中說緩衝資料被儲存在類似陣列的結構中,基本和陣列的操作差不多:建立物件、讀、寫、分割、拷貝、合併等。

1).建立

Buffer物件是在原始的記憶體分配區,在建立的時候確定大小。

//    1.位元組大小 2.八位位元組緩衝區 3.UTF8字串
var  buffer256=new  Buffer(256);
var  bufferOctets=new Buffer([0x6f,0x63,0x74,0x65,0x74,0x73]);
var bufferUTF8=new  Buffer("Some UTF8 Text",'utf8');

2).寫(方法好多)

var buf256=new Buffer(25);
//fill(value,[offset],[end]) 將value寫到緩衝區從offset索引(預設0)處開始,並在end索引處結束的每個位元組(預設buffer長度)
buf256.fill("1",0);
console.log(buf256.toString());
//wirte(string,[offset],[length],[encoding]) 使用encoding編碼從緩衝區offset索引開始寫入string中length數量的位元組
buf256.write("abc",1,2,'utf8');
console.log(buf256.toString());
buf256[6]=56;//將索引處的資料替換為指定的value值
console.log(buf256.toString());

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe Buffer.js
1111111111111111111111111
1ab1111111111111111111111
1ab1118111111111111111111

Process finished with exit code 0

3).讀(可逆,有寫就有讀)

var bufUTF8=new  Buffer("Some UTF8 Text",'utf8');
console.log(bufUTF8.toString());
//toString([encoding],[start],[end]) 使用encoding編碼,讀取從start(0)到end(尾)
console.log(bufUTF8.toString('utf8',0,4));
//返回緩衝區在指定offset位元組的八進位制值
console.log(bufUTF8[8].toString(16));
//Node.js提供StringDecoder物件,有一個write(buffer)來進行解碼,並使用指定的編碼寫入緩衝區資料
var StringDecoder=require('string_decoder').StringDecoder;
var decoder=new StringDecoder('utf8');
console.log(decoder.write(bufUTF8));

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe Buffer.js
Some UTF8 Text
Some
38
Some UTF8 Text

Process finished with exit code 0

4.Buffer長度

Buffer的長度是計算的位元組長度,字串的長度是字元的長度.

var s='UTF8 text u00b6';
console.log(s.length);
console.log(Buffer.byteLength(s,'utf8'));
console.log(Buffer(s).length)

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe Buffer.js
11
12
12

Process finished with exit code 0

5.複製緩衝區 主要是copy方法

var bufSource=new  Buffer("1234567890",'utf8');
var bufTarget=new  Buffer("abcedfghijklmn",'utf8');
//copy.(targetBuffer, targetStart, sourceStart, sourceEnd)
//bufSource.copy(bufTarget,10,3,9); //abcedfghij4567
bufSource.copy(bufTarget,0,3,9);//456789ghijklmn
console.log(bufTarget.toString());

6.對緩衝區切片

這個有點類似字串擷取.slice([start],[end]),返回一個Buffer物件.如果編輯一個切片也會改變原來的緩衝區。

var  number=new Buffer('123456789');
console.log(number.toString());
var slice=number.slice(3.9);
console.log(slice.toString());
slice[0]='#'.charCodeAt(0);
slice[slice.length-1]='#'.charCodeAt(0);
console.log(slice.toString());
console.log(number.toString());

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe Buffer.js
123456789
456789
#5678#
123#5678#

Process finished with exit code 0

7.拼接緩衝區

這個有點類似C中的字串拼接.concat(list,[totalLength])可以把多個Buffer物件拼接在一起形成一個新的緩衝區.

var buff1 = new Buffer("123");
var buff2 = new Buffer("abc");
console.log(Buffer.concat([buff1, buff2,buff1]).toString());

輸出結果:

"C:Program Files (x86)JetBrainsWebStorm 11.0.3binrunnerw.exe" F:nodejsnode.exe buffer_concat.js
123abc123

Process finished with exit code 0

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com