• Node.js Video Tutorials

Node.js - Buffer.writeUIntBE() 方法



NodeJS 的 Buffer.writeUIntBE() 方法用于以大端序形式将指定长度的无符号字节值写入缓冲区的指定偏移量。

语法

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

buf.writeUIntBE(value, offset, bytelength)

参数

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

  • value − (必填) 要写入缓冲区的无符号数字。

  • offset − (必填) 指示写入起始位置的偏移量。偏移量必须大于等于 0,并且小于等于 buffer.length - byteLength。默认值为 0。

  • byteLength − (必填) 要写入的字节数。byteLength 必须介于 0 到 6 之间。

返回值

NodeJS 的 buffer.writeUIntBE() 方法写入给定值并返回偏移量加上写入的字节数。

示例

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

const buffer = Buffer.alloc(10);
buffer.writeUIntBE(123, 0, 6);
console.log(buffer);

输出

我们使用的偏移量为 0,字节长度为 6。执行后,从第 0 位开始的值将写入创建的缓冲区。上述创建的缓冲区长度为 10。因此,我们只能使用 0 到 4 之间的偏移量值。任何大于 4 的值都会引发 ERR_OUT_OF_RANGE 错误。

<Buffer 00 00 00 00 00 7b 00 00 00 00>

示例

在这个例子中,我们将使用一个大于 6 的字节长度。它应该抛出如下所示的错误。

const buffer = Buffer.alloc(10);
buffer.writeUIntBE(123, 0, 8);
console.log(buffer);

输出

internal/buffer.js:58
   throw new ERR_OUT_OF_RANGE(type || 'offset',
   ^
   
RangeError [ERR_OUT_OF_RANGE]: The value of "byteLength" is out of range. It must be >= 1 and <= 6. Received 8
   at boundsError (internal/buffer.js:58:9)
   at Buffer.writeUIntBE (internal/buffer.js:599:3)
   at Object.<anonymous> (C:\nodejsProject\src\testbuffer.js:2:8)
   at Module._compile (internal/modules/cjs/loader.js:816:30)
   at Object.Module._extensions..js (internal/modules/cjs/loader.js:827:10)
   at Module.load (internal/modules/cjs/loader.js:685:32)
   at Function.Module._load (internal/modules/cjs/loader.js:620:12)
   at Function.Module.runMain (internal/modules/cjs/loader.js:877:12)
   at internal/main/run_main_module.js:21:11

示例

在这个例子中,我们将使用一个大于 buffer.length - bytelength 的偏移量。

const buffer = Buffer.alloc(10);
buffer.writeUIntBE(123, 8, 3);
console.log(buffer);

输出

偏移量必须在 0 到 7 之间。由于我们使用了 8,它将抛出如下所示的错误:

internal/buffer.js:58
   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 <= 7. Received 8
   at boundsError (internal/buffer.js:58:9)
   at checkBounds (internal/buffer.js:39:5)
   at checkInt (internal/buffer.js:46:3)
   at writeU_Int24BE (internal/buffer.js:654:3)
   at Buffer.writeUIntBE (internal/buffer.js:591:12)
   at Object.<anonymous> (C:\nodejsProject\src\testbuffer.js:2:8)
   at Module._compile (internal/modules/cjs/loader.js:816:30)
   at Object.Module._extensions..js (internal/modules/cjs/loader.js:827:10)
   at Module.load (internal/modules/cjs/loader.js:685:32)
   at Function.Module._load (internal/modules/cjs/loader.js:620:12)
nodejs_buffer_module.htm
广告