Node.js中的缓冲与流模块详细介绍中的缓冲与流模块详细介绍
缓冲(缓冲(buffer)模块)模块
js起初就是为浏览器而设计的,所以能很好的处理unicode编码的字符串,但不能很好的处理二进制数据。这是Node.js的一个
问题,因为Node.js旨在网络上发送和接收经常是以二进制格式传输的数据。比如:
– 通过TCP连接发送和接收数据;
– 从图像或者压缩文件读取二进制数据;
– 从文件系统读写数据;
– 处理来自网络的二进制数据流
而Buffer模块为Node.js带来了一种存储原始数据的方法,于是可以再js的上下文中使用二进制数据。每当需要在Node.js中处
理I/O操作中移动的数据时,就有可能使用Buffer模块。
类:类:Buffer
Buffer 类是一个全局变量类型,用来直接处理2进制数据的。 它能够使用多种方式构建。
原始数据保存在 Buffer 类的实例中。一个 Buffer 实例类似于一个整数数组
1.new Buffer(size):分配一个新的 buffer 大小是 size 的8位字节.
2.new Buffer(array):分配一个新的 buffer 使用一个8位字节 array 数组.
3.new Buffer(str, [encoding]):encoding String类型 – 使用什么编码方式,参数可选.
4.类方法: Buffer.isEncoding(encoding):如果给定的编码 encoding 是有效的,返回 true,否则返回 false。
5.类方法: Buffer.isBuffer(obj):测试这个 obj 是否是一个 Buffer. 返回Boolean
6.类方法: Buffer.concat(list, [totalLength]):list {Array}数组类型,Buffer数组,用于被连接。totalLength {Number}类型 上述
Buffer数组的所有Buffer的总大小。
除了可以读取文件得到Buffer的实例外,还能够直接构造,例如:
代码如下:
var bin = new Buffer([ 0x48, 0x65, 0x6c, 0x6c, 0x6c ]);
Buffer与字符串类似,除了可以用.length属性得到字节长度外,还可以用[index]方式读取指定位置的字节,例如:
代码如下:
bin[0]; // => 0x48;
Buffer与字符串能够互相转化,例如可以使用指定编码将二进制数据转化为字符串:
代码如下:
var str = bin.toString(‘utf-8’); // => “hello”
.slice方法不是返回一个新的Buffer,而更像是返回了指向原Buffer中间的某个位置的指针,如下所示。
代码如下:
1.[ 0x48, 0x65, 0x6c, 0x6c, 0x6c ] 2. ^ ^
3. | |
4. bin bin.slice(2)
写入缓冲区写入缓冲区
代码如下:
var buffer = new Buffer(8);//创建一个分配了8个字节内存的缓冲区
console.log(buffer.write(‘a’,’utf8′));//输出1
这会将字符”a”写入缓冲区,node返回经过编码以后写入缓冲区的字节数量,这里的字母a的utf-8编码占用1个字节。
复制缓冲区复制缓冲区
Node.js提供了一个将Buffer对象整体内容复制到另一个Buffer对象中的方法。我们只能在已经存在的Buffer对象之间复制,所
以必须创建它们。
代码如下:
buffer.copy(bufferToCopyTo)
其中,bufferToCopyTo是要复制的目标Buffer对象。如下示例:
代码如下:
var buffer1 = new Buffer(8);
buffer1.write(‘nice to meet u’,’utf8′);
var buffer2 = new Buffer(8);
buffer1.copy(buffer2);
console.log(buffer2.toString());//nice to meet u
流模块流模块
在UNIX类型的操作系统中,流是个标准的概念。有如下三个主要的流: