• Node.js Video Tutorials

Node.js - Buffer.writeBigInt64LE() 方法



Buffer.writeBigInt64LE() 方法用于以小端序形式将带符号的 64 位整数写入缓冲区的指定偏移量。写入缓冲区的整数以二进制补码带符号值表示。

语法

以下是 Node.JS Buffer.writeBigInt64LE() 方法的语法:

buf.writeBigInt64LE(value[, offset])

参数

此方法接受两个参数,解释如下。

  • value − (必需)要写入缓冲区的带符号 64 位整数。

  • offset − 此偏移量指示开始写入的位置。偏移量必须大于或等于 0,小于或等于 buffer.length-8。默认值为 0。

返回值

buf.writeBigInt64LE() 方法写入 64 位带符号整数 value 并返回 offset 加上写入的字节数。

示例

要创建缓冲区,我们将使用 NodeJS Buffer.alloc() 方法:

const buffer = Buffer.alloc(10);
buffer.writeBigInt64LE(0x0108890060708n, 0);
console.log(buffer);

输出

我们在此方法中使用的偏移量为 0。执行时,将把第 0 位上的 64 位带符号整数写入创建的缓冲区。上面创建的缓冲区长度为 10。因此,我们只能使用 0 到 2 之间的偏移量值。任何大于 2 的值都会引发 ERR_OUT_OF_RANGE 错误。

<Buffer 08 07 06 90 88 10 00 00 00 00>

示例

在此示例中,我们将使用一个大于 buffer.length − 8 的偏移量。它应该抛出如下所示的错误。

const buffer = Buffer.alloc(10);
buffer.writeBigInt64LE(0x0108890060708n, 3);
console.log(buffer);

输出

internal/buffer.js:83
   throw new ERR_OUT_OF_RANGE(type || 'offset',
   ^
   
RangeError [ERR_OUT_OF_RANGE]: The value of "offset" is out of range. It must be >= 0 and <= 2. Received 3
   at boundsError (internal/buffer.js:83:9)
   at checkBounds (internal/buffer.js:52:5)
   at checkInt (internal/buffer.js:71:3)
   at writeBigU_Int64LE (internal/buffer.js:576:3)
   at Buffer.writeBigInt64LE (internal/buffer.js:628:10)
   at Object.<anonymous> (C:\nodejsProject\src\testbuffer.js:2:8)
   at Module._compile (internal/modules/cjs/loader.js:1063:30)
   at Object.Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
   at Module.load (internal/modules/cjs/loader.js:928:32)
   at Function.Module._load (internal/modules/cjs/loader.js:769:14) {
      code: 'ERR_OUT_OF_RANGE'
   }

示例

要创建缓冲区,我们将使用 Buffer.allocUnsafe() 方法:

const buffer = Buffer.allocUnsafe(10);
buffer.writeBigInt64LE(0x010060708n);
console.log(buffer);

输出

未使用偏移量,默认情况下将取 0。因此,上面的输出如下所示:

<Buffer 08 07 06 10 00 00 00 00 00 00>
nodejs_buffer_module.htm
广告