nodejs之Buffer学习笔记(一)

 后端   大苹果   2018-05-10 16:38   6377
  Buffer node

类方法: Buffer.alloc(size[, fill[, encoding]])

History

版本
变化
v8.9.3指定无效的字符串填充将会被替换为0来填充缓冲区。
v5.10.0新增于: v5.10.0

参数

参数字段类型说明
sizeinteger指定新创建的Buffer大小
fillstring | Buffer | integer指定填充Buffer的值。 Default: 0
encoding<string>如果填充的是字符串,这个参数指定的就是字符串的编码。 默认: 'utf8'

分配一个指定字节大小的新Buffer。如果填充未定义,则Buffer将被零填充。

const buf = Buffer.alloc(5);
// Prints: <Buffer 00 00 00 00 00>
console.log(buf);

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

新增于: v0.1.90

  • encoding <string> 要解码的字符编码。 默认: 'utf8'

  • start <integer> 开始解码的字节偏移量。 默认: 0

  • end <integer> 在(不包括)停止解码的字节偏移量. 默认: buf.length

  • Returns: <string> 根据编码中指定的字符编码将BUF解码为字符串。可以通过开始和结束仅解码BUF的子集

字符串实例的最大长度(在UTF-16编码单元中)可以作为Buffer-Struts.Max String长度来使用。

const buf2 = Buffer.alloc(11, "你好12345", 'utf8');
// 以下输出: <Buffer e4 bd a0 e5 a5 bd 31 32 33 34 35>
console.log(buf2);
// 以下输出: 你好12345
console.log(buf2.toString('utf8'));
const buf3 = Buffer.alloc(11, "你好123456", 'utf8');
// 以下输出: <Buffer e4 bd a0 e5 a5 bd 31 32 33 34 35>
console.log(buf2);
// 以下输出: 你好12345 => buf3长度11,utf-8编码中一个汉字占三个字节,你好123456共12个字节,所以丢失一个字节
console.log(buf2.toString('utf8'));