稳定性: 2 - 稳定

    Buffer 对象用于表示固定长度的字节序列。 许多 Node.js API 都支持 Buffer

    Buffer 类是 JavaScript 的 [Uint8Array] 类的子类,且继承时带上了涵盖额外用例的方法。 只要支持 Buffer 的地方,Node.js API 都可以接受普通的 [Uint8Array]。

    Buffer 类在全局作用域中,因此无需使用 require('buffer').Buffer

    1. // 创建一个长度为 10、以零填充的 Buffer。
    2. const buf1 = Buffer.alloc(10);
    3. // 创建一个长度为 10 的 Buffer,
    4. // 其中全部填充了值为 `1` 的字节。
    5. const buf2 = Buffer.alloc(10, 1);
    6. // 创建一个长度为 10、且未初始化的 buffer。
    7. // 这个方法比调用 Buffer.alloc() 更快,
    8. // 但返回的 Buffer 实例可能包含旧数据,
    9. // 因此需要使用 fill()、write() 或其他能填充 Buffer 的内容的函数进行重写。
    10. const buf3 = Buffer.allocUnsafe(10);
    11. // 创建一个包含字节 [1, 2, 3] 的 Buffer。
    12. const buf4 = Buffer.from([1, 2, 3]);
    13. // 创建一个包含字节 [1, 1, 1, 1] 的 Buffer,
    14. // 其中所有条目均使用 `(value & 255)` 进行截断以符合 0-255 的范围。
    15. const buf5 = Buffer.from([257, 257.5, -255, '1']);
    16. // 创建一个 Buffer,其中包含字符串 'tést' 的 UTF-8 编码字节:
    17. // [0x74, 0xc3, 0xa9, 0x73, 0x74](以十六进制表示)
    18. // [116, 195, 169, 115, 116](以十进制表示)
    19. const buf6 = Buffer.from('tést');
    20. // 创建一个包含 Latin-1 字节 [0x74, 0xe9, 0x73, 0x74] 的 Buffer。
    21. const buf7 = Buffer.from('tést', 'latin1');