buf.readUInt32BE([offset])
Версия | Изменения |
---|---|
v14.9.0, v12.19.0 | Эта функция также доступна как buf.readUint32BE() . |
v10.0.0 | Удалено noAssert , и больше нет неявного принуждения к смещению uint32 . |
v0.5.5 | Добавлено в: v0.5.5 |
offset
<целое число> Количество байтов, которые необходимо пропустить перед началом чтения.- Должен удовлетворить
0 <= offset <= buf.length - 4
. - По умолчанию:
0
. - Возвращает: <целое число>
Считывает 32-разрядное целое число без знака с большим концом из buf
указанного offset
.
Эта функция также доступна под readUint32BE
псевдонимом.
import { Buffer } from 'buffer';
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78]);
console.log(buf.readUInt32BE(0).toString(16));
// Prints: 12345678
const { Buffer } = require('buffer');
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78]);
console.log(buf.readUInt32BE(0).toString(16));
// Prints: 12345678
Метод Buffer.readUInt32BE() представляет собой встроенный интерфейс прикладного программирования класса Buffer в модуле Buffer, который используется для считывания 32-разрядного значения из выделенного буфера с заданным смещением.
Синтаксис:
Buffer.readUInt32BE( offset )
Параметры: Этот метод принимает один параметр offset который определяет количество байтов, которые нужно пропустить перед чтением, или просто обозначает индекс в буфере. Значение смещения лежит 0 <= offset <= Buffer.length – 4 его значение по умолчанию равно 0.
Return Value (Возвращаемое Значение): Этот метод возвращает целое значение, которое считывается из буфера в формате Big Endian.
Приведенные ниже примеры иллюстрируют использование метода Buffer.readUInt32BE() в Node.js:
Пример 1:
// Node program to demonstrate the
// Buffer.readUInt32LE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98,
0x16, 0x09, 0x19, 0x96]);
// Printing allocated buffer
console.log(buf);
// Reading 32 bits data from the buffer
// and printing it as a string
console.log(buf.readUInt32BE(0).toString(16));
console.log(buf.readUInt32BE(1).toString(16));
console.log(buf.readUInt32BE(2).toString(16));
console.log(buf.readUInt32BE(3).toString(16));
console.log(buf.readUInt32BE(4).toString(16));
Выход:
<Buffer 21 09 19 98 16 09 19 96> 21091998
9199816
19981609
98160919
16091996
Пример 2:
// Node program to demonstrate the
// Buffer.readUInt32LE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98,
0x34, 0xae, 0xe8, 0xff]);
// Printing allocated buffer
console.log(buf);
// Reading 16bits data from the
// buffer and printing it as a string
console.log(buf.readUInt32BE(0).toString(16));
console.log(buf.readUInt32LE(0).toString(16));
console.log(buf.readUInt32BE(1).toString(16));
console.log(buf.readUInt32LE(1).toString(16));
console.log(buf.readUInt32BE(2).toString(16));
console.log(buf.readUInt32LE(2).toString(16));
console.log(buf.readUInt32BE(3).toString(16));
console.log(buf.readUInt32LE(3).toString(16));
console.log(buf.readUInt32BE(4).toString(16));
console.log(buf.readUInt32LE(4).toString(16));
Выход:
<Buffer 21 09 19 98 34 ae e8 ff> 21091998
98190921
9199834
34981909
199834ae ae349819 9834aee8 e8ae3498 34aee8ff ffe8ae34
Пример 3:
// Node program to demonstrate the
// Buffer.readUInt32LE() Method
// Allocating buffer from array
const buf = Buffer.from([0x21, 0x09, 0x19, 0x98]);
// Printing allocated buffer
console.log(buf);
// Reading 16bits data from the buffer
// and printing it as a string
console.log(buf.readUInt32BE(0).toString(16));
// Wrong index is provoded to produce error
console.log(buf.readUInt32BE(1).toString(16));
Выход:
<Buffer 21 09 19 98>
21091998
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 <= 0. Received 1
at boundsError (internal/buffer.js:49:9)
at Buffer.readUInt32BE (internal/buffer.js:192:5)
. . .
Примечание: Приведенная выше программа будет скомпилирована и запущена с помощью node index.js
команды.
Ссылка: https://nodejs.org/api/buffer.html#buffer_buf_readuint32be_offset