buf.readUIntLE(offset, byteLength)
Версия | Изменения |
---|---|
v14.9.0, v12.19.0 | Эта функция также доступна как buf.readUintLE() . |
v10.0.0 | Удалено noAssert и больше нет неявного принуждения к смещению и byteLengthuint32 |
v0.11.15 | Добавлено в: v0.11.15 |
offset
<целое число> Количество байтов, которые необходимо пропустить перед началом чтения.- Должен удовлетворить
0 <= offset <= buf.length - byteLength
. byteLength
<целое число> Количество считываемых байтов.- Должен удовлетворить
0 < byteLength <= 6
. - Возвращает: <целое число>
Считывает byteLength
количество байтов из buf
указанного offset
и интерпретирует результат как целое число без знака с малым концом, поддерживающее точность до 48 бит.
Эта функция также доступна под readUintLE
псевдонимом.
import { Buffer } from 'buffer';
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78, 0x90, 0xab]);
console.log(buf.readUIntLE(0, 6).toString(16));
// Prints: ab9078563412
const { Buffer } = require('buffer');
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78, 0x90, 0xab]);
console.log(buf.readUIntLE(0, 6).toString(16));
// Prints: ab9078563412
Метод Buffer.readUIntLE() представляет собой встроенный интерфейс прикладного программирования класса Buffer в модуле Buffer, который используется для считывания указанного количества байтов значения из выделенного буфера с заданным смещением.
Синтаксис:
Buffer.readUIntLE( offset, byteLength )
Параметры: Этот метод принимает два параметра, как указано выше и описано ниже:
- offset (смещение): Он указывает количество байтов, которые необходимо пропустить перед чтением, или просто указывает индекс в буфере. Значение смещения лежит 0 <= смещение. Его значение по умолчанию равно 0.
- byteLength (По длине): В нем указывается количество считываемых байтов. Значение длины байта заключается 0 < Длина байта.
Return Value (Возвращаемое Значение): Этот метод возвращает целое значение, которое считывается из буфера в формате Little Endian.
Приведенные ниже примеры иллюстрируют использование метода Buffer.readUIntLE() в Node.js:
Пример 1:
// Node program to demonstrate the
// Buffer.readUIntLE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98]);
// Printing allocated buffer
console.log(buf);
// Reading data from the buffer
// and printing it as a string
console.log(buf.readUIntLE(0, 3).toString(16));
console.log(buf.readUIntLE(1, 3).toString(16));
console.log(buf.readUIntLE(2, 2).toString(16));
Выход:
<Buffer 21 09 19 98> 190921
981909
9819
Пример 2:
// Node program to demonstrate the
// Buffer.readUIntLE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98]);
// Printing allocated buffer
console.log(buf);
// Reading data from the buffer
// and printing it as a string
console.log(buf.readUIntLE(0, 3).toString(16));
console.log(buf.readUIntBE(0, 3).toString(16));
console.log(buf.readUIntLE(1, 2).toString(16));
console.log(buf.readUIntBE(1, 2).toString(16));
console.log(buf.readUIntLE(2, 1).toString(16));
console.log(buf.readUIntBE(2, 1).toString(16));
Выход:
<Buffer 21 09 19 98>
190921
210919
1909
919
19
19
Пример 3:
// Node program to demonstrate the
// Buffer.readUIntLE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98]);
// Printing allocated buffer
console.log(buf);
// Reading data from the buffer
// and printing it as a string
console.log(buf.readUIntLE(0, 4).toString(16));
console.log(buf.readUIntLE(1, 2).toString(16));
console.log(buf.readUIntLE(2, 3).toString(16));
// Wrong index is provoded to produce error
console.log(buf.readUIntLE(3, 6).toString(16));
Выход:
<Buffer 21 09 19 98>
98190921
1909
internal/buffer.js:49
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 <= 1. Received 2
at boundsError (internal/buffer.js:49:9)
at readUInt24LE (internal/buffer.js:118:5)
at Buffer.readUIntLE (internal/buffer.js:61:12)
. . .
Примечание: Вышеуказанная программа будет скомпилирована и запущена с помощью node index.js
Ссылка: https://nodejs.org/api/buffer.html#buffer_buf_readuintle_offset_bytelength