buffer

 后端   大苹果   2023-12-01 22:53   245
  Buffer

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

History

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

参数

参数字段 类型 说明
size integer 指定新创建的Buffer大小
fill string \ 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'));