Buffer
admin/discounts.internal.Buffer
Properties
BYTES_PER_ELEMENT
numberRequired[toStringTag]
"Uint8Array"RequiredbyteLength
numberRequiredbyteOffset
numberRequiredlength
numberRequiredMethods
[iterator]
[iterator](): IterableIterator
<number
>
Returns
IterableIterator
<number
>
Inherited from
Uint8Array.[iterator]
at
at(index
): undefined
| number
Takes an integer value and returns the item at that index, allowing for positive and negative integers. Negative integers count back from the last item in the array.
Parameters
index
numberRequiredReturns
undefined
| number
undefined \| number
undefined | numberInherited from
Uint8Array.at
compare
compare(target
, targetStart?
, targetEnd?
, sourceStart?
, sourceEnd?
): 0
| 1
| -1
Compares buf
with target
and returns a number indicating whether buf
comes before, after, or is the same as target
in sort order.
Comparison is based on the actual sequence of bytes in each Buffer
.
0
is returned iftarget
is the same asbuf
1
is returned iftarget
should come beforebuf
when sorted.-1
is returned iftarget
should come afterbuf
when sorted.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from('ABC');
const buf2 = Buffer.from('BCD');
const buf3 = Buffer.from('ABCD');
console.log(buf1.compare(buf1));
// Prints: 0
console.log(buf1.compare(buf2));
// Prints: -1
console.log(buf1.compare(buf3));
// Prints: -1
console.log(buf2.compare(buf1));
// Prints: 1
console.log(buf2.compare(buf3));
// Prints: 1
console.log([buf1, buf2, buf3].sort(Buffer.compare));
// Prints: [ <Buffer 41 42 43>, <Buffer 41 42 43 44>, <Buffer 42 43 44> ]
// (This result is equal to: [buf1, buf3, buf2].)
The optional targetStart
, targetEnd
, sourceStart
, and sourceEnd
arguments can be used to limit the comparison to specific ranges within target
and buf
respectively.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([1, 2, 3, 4, 5, 6, 7, 8, 9]);
const buf2 = Buffer.from([5, 6, 7, 8, 9, 1, 2, 3, 4]);
console.log(buf1.compare(buf2, 5, 9, 0, 4));
// Prints: 0
console.log(buf1.compare(buf2, 0, 6, 4));
// Prints: -1
console.log(buf1.compare(buf2, 5, 6, 5));
// Prints: 1
ERR_OUT_OF_RANGE
is thrown if targetStart < 0
, sourceStart < 0
,targetEnd > target.byteLength
, or sourceEnd > source.byteLength
.
Parameters
target
Uint8ArrayRequiredBuffer
or Uint8Array with which to compare buf
.targetStart
numbertarget
at which to begin comparison.targetEnd
numbertarget
at which to end comparison (not inclusive).sourceStart
numberbuf
at which to begin comparison.sourceEnd
numberbuf
at which to end comparison (not inclusive).Returns
0
| 1
| -1
``0`` \| ``1`` \| ``-1``
0 | 1 | -1Since
v0.11.13
copy
copy(target
, targetStart?
, sourceStart?
, sourceEnd?
): number
Copies data from a region of buf
to a region in target
, even if the target
memory region overlaps with buf
.
TypedArray.prototype.set()
performs the same operation, and is available
for all TypedArrays, including Node.js Buffer
s, although it takes
different function arguments.
import { Buffer } from 'node:buffer';
// Create two `Buffer` instances.
const buf1 = Buffer.allocUnsafe(26);
const buf2 = Buffer.allocUnsafe(26).fill('!');
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
// Copy `buf1` bytes 16 through 19 into `buf2` starting at byte 8 of `buf2`.
buf1.copy(buf2, 8, 16, 20);
// This is equivalent to:
// buf2.set(buf1.subarray(16, 20), 8);
console.log(buf2.toString('ascii', 0, 25));
// Prints: !!!!!!!!qrst!!!!!!!!!!!!!
import { Buffer } from 'node:buffer';
// Create a `Buffer` and copy data from one region to an overlapping region
// within the same `Buffer`.
const buf = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf[i] = i + 97;
}
buf.copy(buf, 0, 4, 10);
console.log(buf.toString());
// Prints: efghijghijklmnopqrstuvwxyz
Parameters
target
Uint8ArrayRequiredBuffer
or Uint8Array to copy into.targetStart
numbertarget
at which to begin writing.sourceStart
numberbuf
from which to begin copying.sourceEnd
numberbuf
at which to stop copying (not inclusive).Returns
number
number
numberSince
v0.1.90
copyWithin
copyWithin(target
, start
, end?
): Buffer
Returns the this object after copying a section of the array identified by start and end to the same array starting at position target
Parameters
target
numberRequiredstart
numberRequiredend
numberReturns
Inherited from
Uint8Array.copyWithin
entries
entries(): IterableIterator
<[number
, number
]>
Creates and returns an iterator of [index, byte]
pairs from the contents
of buf
.
Returns
IterableIterator
<[number
, number
]>
Since
v1.1.0
Overrides
Uint8Array.entries
equals
equals(otherBuffer
): boolean
Returns true
if both buf
and otherBuffer
have exactly the same bytes,false
otherwise. Equivalent to buf.compare(otherBuffer) === 0
.
Parameters
otherBuffer
Uint8ArrayRequiredBuffer
or Uint8Array with which to compare buf
.Returns
boolean
boolean
booleanSince
v0.11.13
every
every(predicate
, thisArg?
): boolean
Determines whether all the members of an array satisfy the specified test.
Parameters
predicate
(value: number, index: number, array: Uint8Array) => unknownRequiredthisArg
anyReturns
boolean
boolean
booleanInherited from
Uint8Array.every
fill
fill(value
, offset?
, end?
, encoding?
): Buffer
Fills buf
with the specified value
. If the offset
and end
are not given,
the entire buf
will be filled:
import { Buffer } from 'node:buffer';
// Fill a `Buffer` with the ASCII character 'h'.
const b = Buffer.allocUnsafe(50).fill('h');
console.log(b.toString());
// Prints: hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
// Fill a buffer with empty string
const c = Buffer.allocUnsafe(5).fill('');
console.log(c.fill(''));
// Prints: <Buffer 00 00 00 00 00>
value
is coerced to a uint32
value if it is not a string, Buffer
, or
integer. If the resulting integer is greater than 255
(decimal), buf
will be
filled with value & 255
.
If the final write of a fill()
operation falls on a multi-byte character,
then only the bytes of that character that fit into buf
are written:
If value
contains invalid characters, it is truncated; if no valid
fill data remains, an exception is thrown:
Parameters
value
string | number | Uint8ArrayRequiredbuf
. Empty value (string, Uint8Array, Buffer) is coerced to 0
.offset
numberbuf
.end
numberbuf
(not inclusive).encoding
BufferEncodingvalue
if value
is a string.Returns
buf
.Since
v0.5.0
Overrides
Uint8Array.fill
filter
filter(predicate
, thisArg?
): Uint8Array
Returns the elements of an array that meet the condition specified in a callback function.
Parameters
predicate
(value: number, index: number, array: Uint8Array) => anyRequiredthisArg
anyReturns
Uint8Array
Uint8Array
Uint8ArrayRequiredInherited from
Uint8Array.filter
find
find(predicate
, thisArg?
): undefined
| number
Returns the value of the first element in the array where predicate is true, and undefined otherwise.
Parameters
predicate
(value: number, index: number, obj: Uint8Array) => booleanRequiredthisArg
anyReturns
undefined
| number
undefined \| number
undefined | numberInherited from
Uint8Array.find
findIndex
findIndex(predicate
, thisArg?
): number
Returns the index of the first element in the array where predicate is true, and -1 otherwise.
Parameters
predicate
(value: number, index: number, obj: Uint8Array) => booleanRequiredthisArg
anyReturns
number
number
numberInherited from
Uint8Array.findIndex
forEach
forEach(callbackfn
, thisArg?
): void
Performs the specified action for each element in an array.
Parameters
callbackfn
(value: number, index: number, array: Uint8Array) => voidRequiredthisArg
anyReturns
void
void
voidInherited from
Uint8Array.forEach
includes
includes(value
, byteOffset?
, encoding?
): boolean
Equivalent to buf.indexOf() !== -1
.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this is a buffer');
console.log(buf.includes('this'));
// Prints: true
console.log(buf.includes('is'));
// Prints: true
console.log(buf.includes(Buffer.from('a buffer')));
// Prints: true
console.log(buf.includes(97));
// Prints: true (97 is the decimal ASCII value for 'a')
console.log(buf.includes(Buffer.from('a buffer example')));
// Prints: false
console.log(buf.includes(Buffer.from('a buffer example').slice(0, 8)));
// Prints: true
console.log(buf.includes('this', 4));
// Prints: false
Parameters
byteOffset
numberbuf
. If negative, then offset is calculated from the end of buf
.encoding
BufferEncodingvalue
is a string, this is its encoding.Returns
boolean
boolean
booleantrue
if value
was found in buf
, false
otherwise.Since
v5.3.0
Overrides
Uint8Array.includes
indexOf
indexOf(value
, byteOffset?
, encoding?
): number
If value
is:
- a string,
value
is interpreted according to the character encoding inencoding
. - a
Buffer
orUint8Array
,value
will be used in its entirety. To compare a partialBuffer
, usebuf.subarray
. - a number,
value
will be interpreted as an unsigned 8-bit integer value between0
and255
.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this is a buffer');
console.log(buf.indexOf('this'));
// Prints: 0
console.log(buf.indexOf('is'));
// Prints: 2
console.log(buf.indexOf(Buffer.from('a buffer')));
// Prints: 8
console.log(buf.indexOf(97));
// Prints: 8 (97 is the decimal ASCII value for 'a')
console.log(buf.indexOf(Buffer.from('a buffer example')));
// Prints: -1
console.log(buf.indexOf(Buffer.from('a buffer example').slice(0, 8)));
// Prints: 8
const utf16Buffer = Buffer.from('\u039a\u0391\u03a3\u03a3\u0395', 'utf16le');
console.log(utf16Buffer.indexOf('\u03a3', 0, 'utf16le'));
// Prints: 4
console.log(utf16Buffer.indexOf('\u03a3', -4, 'utf16le'));
// Prints: 6
If value
is not a string, number, or Buffer
, this method will throw aTypeError
. If value
is a number, it will be coerced to a valid byte value,
an integer between 0 and 255.
If byteOffset
is not a number, it will be coerced to a number. If the result
of coercion is NaN
or 0
, then the entire buffer will be searched. This
behavior matches String.prototype.indexOf()
.
import { Buffer } from 'node:buffer';
const b = Buffer.from('abcdef');
// Passing a value that's a number, but not a valid byte.
// Prints: 2, equivalent to searching for 99 or 'c'.
console.log(b.indexOf(99.9));
console.log(b.indexOf(256 + 99));
// Passing a byteOffset that coerces to NaN or 0.
// Prints: 1, searching the whole buffer.
console.log(b.indexOf('b', undefined));
console.log(b.indexOf('b', {}));
console.log(b.indexOf('b', null));
console.log(b.indexOf('b', []));
If value
is an empty string or empty Buffer
and byteOffset
is less
than buf.length
, byteOffset
will be returned. If value
is empty andbyteOffset
is at least buf.length
, buf.length
will be returned.
Parameters
value
string | number | Uint8ArrayRequiredbyteOffset
numberbuf
. If negative, then offset is calculated from the end of buf
.encoding
BufferEncodingvalue
is a string, this is the encoding used to determine the binary representation of the string that will be searched for in buf
.Returns
number
number
numbervalue
in buf
, or -1
if buf
does not contain value
.Since
v1.5.0
Overrides
Uint8Array.indexOf
join
join(separator?
): string
Adds all the elements of an array separated by the specified separator string.
Parameters
separator
stringReturns
string
string
stringInherited from
Uint8Array.join
keys
keys(): IterableIterator
<number
>
Creates and returns an iterator of buf
keys (indices).
Returns
IterableIterator
<number
>
Since
v1.1.0
Overrides
Uint8Array.keys
lastIndexOf
lastIndexOf(value
, byteOffset?
, encoding?
): number
Identical to buf.indexOf()
, except the last occurrence of value
is found
rather than the first occurrence.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this buffer is a buffer');
console.log(buf.lastIndexOf('this'));
// Prints: 0
console.log(buf.lastIndexOf('buffer'));
// Prints: 17
console.log(buf.lastIndexOf(Buffer.from('buffer')));
// Prints: 17
console.log(buf.lastIndexOf(97));
// Prints: 15 (97 is the decimal ASCII value for 'a')
console.log(buf.lastIndexOf(Buffer.from('yolo')));
// Prints: -1
console.log(buf.lastIndexOf('buffer', 5));
// Prints: 5
console.log(buf.lastIndexOf('buffer', 4));
// Prints: -1
const utf16Buffer = Buffer.from('\u039a\u0391\u03a3\u03a3\u0395', 'utf16le');
console.log(utf16Buffer.lastIndexOf('\u03a3', undefined, 'utf16le'));
// Prints: 6
console.log(utf16Buffer.lastIndexOf('\u03a3', -5, 'utf16le'));
// Prints: 4
If value
is not a string, number, or Buffer
, this method will throw aTypeError
. If value
is a number, it will be coerced to a valid byte value,
an integer between 0 and 255.
If byteOffset
is not a number, it will be coerced to a number. Any arguments
that coerce to NaN
, like {}
or undefined
, will search the whole buffer.
This behavior matches String.prototype.lastIndexOf()
.
import { Buffer } from 'node:buffer';
const b = Buffer.from('abcdef');
// Passing a value that's a number, but not a valid byte.
// Prints: 2, equivalent to searching for 99 or 'c'.
console.log(b.lastIndexOf(99.9));
console.log(b.lastIndexOf(256 + 99));
// Passing a byteOffset that coerces to NaN.
// Prints: 1, searching the whole buffer.
console.log(b.lastIndexOf('b', undefined));
console.log(b.lastIndexOf('b', {}));
// Passing a byteOffset that coerces to 0.
// Prints: -1, equivalent to passing 0.
console.log(b.lastIndexOf('b', null));
console.log(b.lastIndexOf('b', []));
If value
is an empty string or empty Buffer
, byteOffset
will be returned.
Parameters
value
string | number | Uint8ArrayRequiredbyteOffset
numberbuf
. If negative, then offset is calculated from the end of buf
.encoding
BufferEncodingvalue
is a string, this is the encoding used to determine the binary representation of the string that will be searched for in buf
.Returns
number
number
numbervalue
in buf
, or -1
if buf
does not contain value
.Since
v6.0.0
Overrides
Uint8Array.lastIndexOf
map
map(callbackfn
, thisArg?
): Uint8Array
Calls a defined callback function on each element of an array, and returns an array that contains the results.
Parameters
callbackfn
(value: number, index: number, array: Uint8Array) => numberRequiredthisArg
anyReturns
Uint8Array
Uint8Array
Uint8ArrayRequiredInherited from
Uint8Array.map
readBigInt64BE
readBigInt64BE(offset?
): bigint
Reads a signed, big-endian 64-bit integer from buf
at the specified offset
.
Integers read from a Buffer
are interpreted as two's complement signed
values.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
bigint
bigint
bigintSince
v12.0.0, v10.20.0
readBigInt64LE
readBigInt64LE(offset?
): bigint
Reads a signed, little-endian 64-bit integer from buf
at the specifiedoffset
.
Integers read from a Buffer
are interpreted as two's complement signed
values.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
bigint
bigint
bigintSince
v12.0.0, v10.20.0
readBigUInt64BE
readBigUInt64BE(offset?
): bigint
Reads an unsigned, big-endian 64-bit integer from buf
at the specifiedoffset
.
This function is also available under the readBigUint64BE
alias.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
bigint
bigint
bigintSince
v12.0.0, v10.20.0
readBigUInt64LE
readBigUInt64LE(offset?
): bigint
Reads an unsigned, little-endian 64-bit integer from buf
at the specifiedoffset
.
This function is also available under the readBigUint64LE
alias.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
bigint
bigint
bigintSince
v12.0.0, v10.20.0
readBigUint64BE
readBigUint64BE(offset?
): bigint
Parameters
offset
numberReturns
bigint
bigint
bigintAlias
Buffer.readBigUInt64BE
Since
v14.10.0, v12.19.0
readBigUint64LE
readBigUint64LE(offset?
): bigint
Parameters
offset
numberReturns
bigint
bigint
bigintAlias
Buffer.readBigUInt64LE
Since
v14.10.0, v12.19.0
readDoubleBE
readDoubleBE(offset?
): number
Reads a 64-bit, big-endian double from buf
at the specified offset
.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberSince
v0.11.15
readDoubleLE
readDoubleLE(offset?
): number
Reads a 64-bit, little-endian double from buf
at the specified offset
.
Parameters
offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberSince
v0.11.15
readFloatBE
readFloatBE(offset?
): number
Reads a 32-bit, big-endian float from buf
at the specified offset
.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.11.15
readFloatLE
readFloatLE(offset?
): number
Reads a 32-bit, little-endian float from buf
at the specified offset
.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.11.15
readInt16BE
readInt16BE(offset?
): number
Reads a signed, big-endian 16-bit integer from buf
at the specified offset
.
Integers read from a Buffer
are interpreted as two's complement signed values.
Parameters
offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberSince
v0.5.5
readInt16LE
readInt16LE(offset?
): number
Reads a signed, little-endian 16-bit integer from buf
at the specifiedoffset
.
Integers read from a Buffer
are interpreted as two's complement signed values.
Parameters
offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberSince
v0.5.5
readInt32BE
readInt32BE(offset?
): number
Reads a signed, big-endian 32-bit integer from buf
at the specified offset
.
Integers read from a Buffer
are interpreted as two's complement signed values.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.5.5
readInt32LE
readInt32LE(offset?
): number
Reads a signed, little-endian 32-bit integer from buf
at the specifiedoffset
.
Integers read from a Buffer
are interpreted as two's complement signed values.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.5.5
readInt8
readInt8(offset?
): number
Reads a signed 8-bit integer from buf
at the specified offset
.
Integers read from a Buffer
are interpreted as two's complement signed values.
Parameters
offset
number0 <= offset <= buf.length - 1
.Returns
number
number
numberSince
v0.5.0
readIntBE
readIntBE(offset
, byteLength
): number
Reads byteLength
number of bytes from buf
at the specified offset
and interprets the result as a big-endian, two's complement signed value
supporting up to 48 bits of accuracy.
import { Buffer } from 'node:buffer';
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78, 0x90, 0xab]);
console.log(buf.readIntBE(0, 6).toString(16));
// Prints: 1234567890ab
console.log(buf.readIntBE(1, 6).toString(16));
// Throws ERR_OUT_OF_RANGE.
console.log(buf.readIntBE(1, 0).toString(16));
// Throws ERR_OUT_OF_RANGE.
Parameters
offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberSince
v0.11.15
readIntLE
readIntLE(offset
, byteLength
): number
Reads byteLength
number of bytes from buf
at the specified offset
and interprets the result as a little-endian, two's complement signed value
supporting up to 48 bits of accuracy.
Parameters
offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberSince
v0.11.15
readUInt16BE
readUInt16BE(offset?
): number
Reads an unsigned, big-endian 16-bit integer from buf
at the specifiedoffset
.
This function is also available under the readUint16BE
alias.
Parameters
offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberSince
v0.5.5
readUInt16LE
readUInt16LE(offset?
): number
Reads an unsigned, little-endian 16-bit integer from buf
at the specifiedoffset
.
This function is also available under the readUint16LE
alias.
Parameters
offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberSince
v0.5.5
readUInt32BE
readUInt32BE(offset?
): number
Reads an unsigned, big-endian 32-bit integer from buf
at the specifiedoffset
.
This function is also available under the readUint32BE
alias.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.5.5
readUInt32LE
readUInt32LE(offset?
): number
Reads an unsigned, little-endian 32-bit integer from buf
at the specifiedoffset
.
This function is also available under the readUint32LE
alias.
Parameters
offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberSince
v0.5.5
readUInt8
readUInt8(offset?
): number
Reads an unsigned 8-bit integer from buf
at the specified offset
.
This function is also available under the readUint8
alias.
Parameters
offset
number0 <= offset <= buf.length - 1
.Returns
number
number
numberSince
v0.5.0
readUIntBE
readUIntBE(offset
, byteLength
): number
Reads byteLength
number of bytes from buf
at the specified offset
and interprets the result as an unsigned big-endian integer supporting
up to 48 bits of accuracy.
This function is also available under the readUintBE
alias.
Parameters
offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberSince
v0.11.15
readUIntLE
readUIntLE(offset
, byteLength
): number
Reads byteLength
number of bytes from buf
at the specified offset
and interprets the result as an unsigned, little-endian integer supporting
up to 48 bits of accuracy.
This function is also available under the readUintLE
alias.
Parameters
offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberSince
v0.11.15
readUint16BE
readUint16BE(offset?
): number
Parameters
offset
numberReturns
number
number
numberAlias
Buffer.readUInt16BE
Since
v14.9.0, v12.19.0
readUint16LE
readUint16LE(offset?
): number
Parameters
offset
numberReturns
number
number
numberAlias
Buffer.readUInt16LE
Since
v14.9.0, v12.19.0
readUint32BE
readUint32BE(offset?
): number
Parameters
offset
numberReturns
number
number
numberAlias
Buffer.readUInt32BE
Since
v14.9.0, v12.19.0
readUint32LE
readUint32LE(offset?
): number
Parameters
offset
numberReturns
number
number
numberAlias
Buffer.readUInt32LE
Since
v14.9.0, v12.19.0
readUint8
readUint8(offset?
): number
Parameters
offset
numberReturns
number
number
numberAlias
Buffer.readUInt8
Since
v14.9.0, v12.19.0
readUintBE
readUintBE(offset
, byteLength
): number
Parameters
offset
numberRequiredbyteLength
numberRequiredReturns
number
number
numberAlias
Buffer.readUIntBE
Since
v14.9.0, v12.19.0
readUintLE
readUintLE(offset
, byteLength
): number
Parameters
offset
numberRequiredbyteLength
numberRequiredReturns
number
number
numberAlias
Buffer.readUIntLE
Since
v14.9.0, v12.19.0
reduce
reduce(callbackfn
): number
Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn
(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredReturns
number
number
numberInherited from
Uint8Array.reduce
reduce(callbackfn
, initialValue
): number
Parameters
callbackfn
(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredinitialValue
numberRequiredReturns
number
number
numberInherited from
Uint8Array.reduce
reduce<U
>(callbackfn
, initialValue
): U
Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
U
objectRequiredParameters
callbackfn
(previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => URequiredinitialValue
URequiredReturns
U
Inherited from
Uint8Array.reduce
reduceRight
reduceRight(callbackfn
): number
Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn
(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredReturns
number
number
numberInherited from
Uint8Array.reduceRight
reduceRight(callbackfn
, initialValue
): number
Parameters
callbackfn
(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredinitialValue
numberRequiredReturns
number
number
numberInherited from
Uint8Array.reduceRight
reduceRight<U
>(callbackfn
, initialValue
): U
Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
U
objectRequiredParameters
callbackfn
(previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => URequiredinitialValue
URequiredReturns
U
Inherited from
Uint8Array.reduceRight
reverse
reverse(): Buffer
Returns
Overrides
Uint8Array.reverse
set
set(array
, offset?
): void
Sets a value or an array of values.
Parameters
offset
numberReturns
void
void
voidInherited from
Uint8Array.set
slice
slice(start?
, end?
): Buffer
Returns a new Buffer
that references the same memory as the original, but
offset and cropped by the start
and end
indices.
This method is not compatible with the Uint8Array.prototype.slice()
,
which is a superclass of Buffer
. To copy the slice, useUint8Array.prototype.slice()
.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('buffer');
const copiedBuf = Uint8Array.prototype.slice.call(buf);
copiedBuf[0]++;
console.log(copiedBuf.toString());
// Prints: cuffer
console.log(buf.toString());
// Prints: buffer
// With buf.slice(), the original buffer is modified.
const notReallyCopiedBuf = buf.slice();
notReallyCopiedBuf[0]++;
console.log(notReallyCopiedBuf.toString());
// Prints: cuffer
console.log(buf.toString());
// Also prints: cuffer (!)
Parameters
start
numberBuffer
will start.end
numberBuffer
will end (not inclusive).Returns
Since
v0.3.0
Deprecated
Use subarray
instead.
Overrides
Uint8Array.slice
some
some(predicate
, thisArg?
): boolean
Determines whether the specified callback function returns true for any element of an array.
Parameters
predicate
(value: number, index: number, array: Uint8Array) => unknownRequiredthisArg
anyReturns
boolean
boolean
booleanInherited from
Uint8Array.some
sort
sort(compareFn?
): Buffer
Sorts an array.
Parameters
compareFn
(a: number, b: number) => numberts [11,2,22,1].sort((a, b) => a - b)
Returns
Inherited from
Uint8Array.sort
subarray
subarray(start?
, end?
): Buffer
Returns a new Buffer
that references the same memory as the original, but
offset and cropped by the start
and end
indices.
Specifying end
greater than buf.length
will return the same result as
that of end
equal to buf.length
.
This method is inherited from TypedArray.prototype.subarray()
.
Modifying the new Buffer
slice will modify the memory in the original Buffer
because the allocated memory of the two objects overlap.
import { Buffer } from 'node:buffer';
// Create a `Buffer` with the ASCII alphabet, take a slice, and modify one byte
// from the original `Buffer`.
const buf1 = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
const buf2 = buf1.subarray(0, 3);
console.log(buf2.toString('ascii', 0, buf2.length));
// Prints: abc
buf1[0] = 33;
console.log(buf2.toString('ascii', 0, buf2.length));
// Prints: !bc
Specifying negative indexes causes the slice to be generated relative to the
end of buf
rather than the beginning.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('buffer');
console.log(buf.subarray(-6, -1).toString());
// Prints: buffe
// (Equivalent to buf.subarray(0, 5).)
console.log(buf.subarray(-6, -2).toString());
// Prints: buff
// (Equivalent to buf.subarray(0, 4).)
console.log(buf.subarray(-5, -2).toString());
// Prints: uff
// (Equivalent to buf.subarray(1, 4).)
Parameters
start
numberBuffer
will start.end
numberBuffer
will end (not inclusive).Returns
Since
v3.0.0
Overrides
Uint8Array.subarray
swap16
swap16(): Buffer
Interprets buf
as an array of unsigned 16-bit integers and swaps the
byte order in-place. Throws ERR_INVALID_BUFFER_SIZE
if buf.length
is not a multiple of 2.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap16();
console.log(buf1);
// Prints: <Buffer 02 01 04 03 06 05 08 07>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap16();
// Throws ERR_INVALID_BUFFER_SIZE.
One convenient use of buf.swap16()
is to perform a fast in-place conversion
between UTF-16 little-endian and UTF-16 big-endian:
Returns
buf
.Since
v5.10.0
swap32
swap32(): Buffer
Interprets buf
as an array of unsigned 32-bit integers and swaps the
byte order in-place. Throws ERR_INVALID_BUFFER_SIZE
if buf.length
is not a multiple of 4.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap32();
console.log(buf1);
// Prints: <Buffer 04 03 02 01 08 07 06 05>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap32();
// Throws ERR_INVALID_BUFFER_SIZE.
Returns
buf
.Since
v5.10.0
swap64
swap64(): Buffer
Interprets buf
as an array of 64-bit numbers and swaps byte order in-place.
Throws ERR_INVALID_BUFFER_SIZE
if buf.length
is not a multiple of 8.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap64();
console.log(buf1);
// Prints: <Buffer 08 07 06 05 04 03 02 01>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap64();
// Throws ERR_INVALID_BUFFER_SIZE.
Returns
buf
.Since
v6.3.0
toJSON
toJSON(): { data
: number
[] ; type
: "Buffer"
}
Returns a JSON representation of buf
. JSON.stringify()
implicitly calls
this function when stringifying a Buffer
instance.
Buffer.from()
accepts objects in the format returned from this method.
In particular, Buffer.from(buf.toJSON())
works like Buffer.from(buf)
.
import { Buffer } from 'node:buffer';
const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]);
const json = JSON.stringify(buf);
console.log(json);
// Prints: {"type":"Buffer","data":[1,2,3,4,5]}
const copy = JSON.parse(json, (key, value) => {
return value && value.type === 'Buffer' ?
Buffer.from(value) :
value;
});
console.log(copy);
// Prints: <Buffer 01 02 03 04 05>
Returns
object
`object`
objectdata
number[]Requiredtype
"Buffer"RequiredSince
v0.9.2
toLocaleString
toLocaleString(): string
Converts a number to a string by using the current locale.
Returns
string
string
stringInherited from
Uint8Array.toLocaleString
toString
toString(encoding?
, start?
, end?
): string
Decodes buf
to a string according to the specified character encoding inencoding
. start
and end
may be passed to decode only a subset of buf
.
If encoding
is 'utf8'
and a byte sequence in the input is not valid UTF-8,
then each invalid byte is replaced with the replacement character U+FFFD
.
The maximum length of a string instance (in UTF-16 code units) is available as constants.MAX_STRING_LENGTH.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
console.log(buf1.toString('utf8'));
// Prints: abcdefghijklmnopqrstuvwxyz
console.log(buf1.toString('utf8', 0, 5));
// Prints: abcde
const buf2 = Buffer.from('tést');
console.log(buf2.toString('hex'));
// Prints: 74c3a97374
console.log(buf2.toString('utf8', 0, 3));
// Prints: té
console.log(buf2.toString(undefined, 0, 3));
// Prints: té
Parameters
encoding
BufferEncodingstart
numberend
numberReturns
string
string
stringSince
v0.1.90
Overrides
Uint8Array.toString
valueOf
valueOf(): Uint8Array
Returns the primitive value of the specified object.
Returns
Uint8Array
Uint8Array
Uint8ArrayRequiredInherited from
Uint8Array.valueOf
values
values(): IterableIterator
<number
>
Creates and returns an iterator for buf
values (bytes). This function is
called automatically when a Buffer
is used in a for..of
statement.
Returns
IterableIterator
<number
>
Since
v1.1.0
Overrides
Uint8Array.values
write
write(string
, encoding?
): number
Writes string
to buf
at offset
according to the character encoding inencoding
. The length
parameter is the number of bytes to write. If buf
did
not contain enough space to fit the entire string, only part of string
will be
written. However, partially encoded characters will not be written.
import { Buffer } from 'node:buffer';
const buf = Buffer.alloc(256);
const len = buf.write('\u00bd + \u00bc = \u00be', 0);
console.log(`${len} bytes: ${buf.toString('utf8', 0, len)}`);
// Prints: 12 bytes: ½ + ¼ = ¾
const buffer = Buffer.alloc(10);
const length = buffer.write('abcd', 8);
console.log(`${length} bytes: ${buffer.toString('utf8', 8, 10)}`);
// Prints: 2 bytes : ab
Parameters
string
stringRequiredbuf
.encoding
BufferEncodingstring
.Returns
number
number
numberSince
v0.1.90
write(string
, offset
, encoding?
): number
Parameters
Returns
number
number
numberwrite(string
, offset
, length
, encoding?
): number
Parameters
Returns
number
number
numberwriteBigInt64BE
writeBigInt64BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian.
value
is interpreted and written as a two's complement signed integer.
Parameters
value
bigintRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigInt64LE
writeBigInt64LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian.
value
is interpreted and written as a two's complement signed integer.
Parameters
value
bigintRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUInt64BE
writeBigUInt64BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian.
This function is also available under the writeBigUint64BE
alias.
Parameters
value
bigintRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUInt64LE
writeBigUInt64LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian
This function is also available under the writeBigUint64LE
alias.
Parameters
value
bigintRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUint64BE
writeBigUint64BE(value
, offset?
): number
Parameters
value
bigintRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeBigUInt64BE
Since
v14.10.0, v12.19.0
writeBigUint64LE
writeBigUint64LE(value
, offset?
): number
Parameters
value
bigintRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeBigUInt64LE
Since
v14.10.0, v12.19.0
writeDoubleBE
writeDoubleBE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. The value
must be a JavaScript number. Behavior is undefined when value
is anything
other than a JavaScript number.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeDoubleLE
writeDoubleLE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. The value
must be a JavaScript number. Behavior is undefined when value
is anything
other than a JavaScript number.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 8
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeFloatBE
writeFloatBE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. Behavior is
undefined when value
is anything other than a JavaScript number.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeFloatLE
writeFloatLE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. Behavior is
undefined when value
is anything other than a JavaScript number.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeInt16BE
writeInt16BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. The value
must be a valid signed 16-bit integer. Behavior is undefined when value
is
anything other than a signed 16-bit integer.
The value
is interpreted and written as a two's complement signed integer.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeInt16LE
writeInt16LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. The value
must be a valid signed 16-bit integer. Behavior is undefined when value
is
anything other than a signed 16-bit integer.
The value
is interpreted and written as a two's complement signed integer.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeInt32BE
writeInt32BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. The value
must be a valid signed 32-bit integer. Behavior is undefined when value
is
anything other than a signed 32-bit integer.
The value
is interpreted and written as a two's complement signed integer.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeInt32LE
writeInt32LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. The value
must be a valid signed 32-bit integer. Behavior is undefined when value
is
anything other than a signed 32-bit integer.
The value
is interpreted and written as a two's complement signed integer.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeInt8
writeInt8(value
, offset?
): number
Writes value
to buf
at the specified offset
. value
must be a valid
signed 8-bit integer. Behavior is undefined when value
is anything other than
a signed 8-bit integer.
value
is interpreted and written as a two's complement signed integer.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 1
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.0
writeIntBE
writeIntBE(value
, offset
, byteLength
): number
Writes byteLength
bytes of value
to buf
at the specified offset
as big-endian. Supports up to 48 bits of accuracy. Behavior is undefined whenvalue
is anything other than a
signed integer.
Parameters
value
numberRequiredbuf
.offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeIntLE
writeIntLE(value
, offset
, byteLength
): number
Writes byteLength
bytes of value
to buf
at the specified offset
as little-endian. Supports up to 48 bits of accuracy. Behavior is undefined
when value
is anything other than a signed integer.
Parameters
value
numberRequiredbuf
.offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.11.15
writeUInt16BE
writeUInt16BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. The value
must be a valid unsigned 16-bit integer. Behavior is undefined when value
is anything other than an
unsigned 16-bit integer.
This function is also available under the writeUint16BE
alias.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUInt16LE
writeUInt16LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. The value
must be a valid unsigned 16-bit integer. Behavior is undefined when value
is
anything other than an unsigned 16-bit integer.
This function is also available under the writeUint16LE
alias.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 2
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUInt32BE
writeUInt32BE(value
, offset?
): number
Writes value
to buf
at the specified offset
as big-endian. The value
must be a valid unsigned 32-bit integer. Behavior is undefined when value
is anything other than an
unsigned 32-bit integer.
This function is also available under the writeUint32BE
alias.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUInt32LE
writeUInt32LE(value
, offset?
): number
Writes value
to buf
at the specified offset
as little-endian. The value
must be a valid unsigned 32-bit integer. Behavior is undefined when value
is
anything other than an unsigned 32-bit integer.
This function is also available under the writeUint32LE
alias.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 4
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUInt8
writeUInt8(value
, offset?
): number
Writes value
to buf
at the specified offset
. value
must be a
valid unsigned 8-bit integer. Behavior is undefined when value
is anything
other than an unsigned 8-bit integer.
This function is also available under the writeUint8
alias.
Parameters
value
numberRequiredbuf
.offset
number0 <= offset <= buf.length - 1
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.0
writeUIntBE
writeUIntBE(value
, offset
, byteLength
): number
Writes byteLength
bytes of value
to buf
at the specified offset
as big-endian. Supports up to 48 bits of accuracy. Behavior is undefined
when value
is anything other than an unsigned integer.
This function is also available under the writeUintBE
alias.
Parameters
value
numberRequiredbuf
.offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUIntLE
writeUIntLE(value
, offset
, byteLength
): number
Writes byteLength
bytes of value
to buf
at the specified offset
as little-endian. Supports up to 48 bits of accuracy. Behavior is undefined
when value
is anything other than an unsigned integer.
This function is also available under the writeUintLE
alias.
Parameters
value
numberRequiredbuf
.offset
numberRequired0 <= offset <= buf.length - byteLength
.byteLength
numberRequired0 < byteLength <= 6
.Returns
number
number
numberoffset
plus the number of bytes written.Since
v0.5.5
writeUint16BE
writeUint16BE(value
, offset?
): number
Parameters
value
numberRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeUInt16BE
Since
v14.9.0, v12.19.0
writeUint16LE
writeUint16LE(value
, offset?
): number
Parameters
value
numberRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeUInt16LE
Since
v14.9.0, v12.19.0
writeUint32BE
writeUint32BE(value
, offset?
): number
Parameters
value
numberRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeUInt32BE
Since
v14.9.0, v12.19.0
writeUint32LE
writeUint32LE(value
, offset?
): number
Parameters
value
numberRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeUInt32LE
Since
v14.9.0, v12.19.0
writeUint8
writeUint8(value
, offset?
): number
Parameters
value
numberRequiredoffset
numberReturns
number
number
numberAlias
Buffer.writeUInt8
Since
v14.9.0, v12.19.0
writeUintBE
writeUintBE(value
, offset
, byteLength
): number
Parameters
value
numberRequiredoffset
numberRequiredbyteLength
numberRequiredReturns
number
number
numberAlias
Buffer.writeUIntBE
Since
v14.9.0, v12.19.0
writeUintLE
writeUintLE(value
, offset
, byteLength
): number
Parameters
value
numberRequiredoffset
numberRequiredbyteLength
numberRequiredReturns
number
number
numberAlias
Buffer.writeUIntLE
Since
v14.9.0, v12.19.0