Node.js - Buffer.readUInt16LE() 方法



NodeJS Buffer.readUInt16LE() 方法有助于以小端形式从缓冲区读取给定偏移量的无符号 16 位整数。无符号整数将始终是非负数。

无符号 16 位整数可以存储 0 到 65,535 范围内的值。

语法

以下是Node.JS Buffer.readUInt16LE()方法的语法 -


 buf.readUInt16LE(offset)

参数

  • offset - 指示开始读取的位置的偏移量。偏移量大于或等于 0,也小于或等于 buffer.length-2。默认值为 0。

返回值

此方法从给定偏移量处的缓冲区返回 16 位无符号整数值。

为了创建一个缓冲区,我们将使用 NodeJS Buffer.from() 方法 -


const buffer = Buffer.from([0,15,10,12]);
console.log("buffer stored in memory as", buffer); 	
console.log("Reading 16 bit unsigned integer at offset 0:", buffer.readUInt16LE(0));

输出

我们使用此方法使用的偏移量为 0。第 0 个位置的 16 位无符号整数将被返回。为上述创建的缓冲区长度为 4。因此,我们只能使用值为 0,1 和 2 的偏移量。如果任何值 >2,它将给出错误 ERR_OUT_OF_RANGE

buffer stored in memory as <Buffer 00 0f 0a 0c>
Reading 16 bit unsigned integer at offset 0: 3840

让我们创建一个 16 位的缓冲区,并查看使用 Node.JS Buffer.readUInt16LE() 方法返回的值。


const buffer = Buffer.from([0, 1, 2, 3, 4, 5, 6, 7,8, 9, 10, 11,12, 13, 14, 15]);
console.log("Length of buffer is ", buffer.length); 	
console.log("Reading at big integer at offset 2:", buffer.readUInt16LE(2));

输出

Length of buffer is 16
Reading at big integer at offset 2: 770

此示例将检查偏移量是否大于 buffer.length −2 的错误。让我们创建一个长度为 8 的缓冲区,这样,您可以偏移从 0 到 6 的值。在下面的示例中,我们使用了偏移量 7,因此它将抛出一个错误,如输出中所示。


const buffer = Buffer.from([0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff]);
console.log("buffer length is ", buffer.length); 	
console.log("Reading at big integer at offset 7:", buffer.readUInt16LE(7));

输出

buffer length is 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. ReceivePS C:\nodejsProject> node src/testbuffer.js
buffer length is 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 <= 6. Received 7
at boundsError (internal/buffer.js:58:9)
at Buffer.readUInt16LE (internal/buffer.js:139:5)
at Object.<anonymous> (C:\nodejsProject\src\testbuffer.js:3:59)
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