Packages

trait BufferConstructor extends Object with StObject with Instantiable1[|[|[|[|[|[|[Any, Array[Any]], ArrayBuffer], Buffer], Double], String], Uint8Array], Buffer] with Instantiable2[String, BufferEncoding, Buffer]

Raw data is stored in instances of the Buffer class. A Buffer is similar to an array of integers but corresponds to a raw memory allocation outside the V8 heap. A Buffer cannot be resized. Valid string encodings: 'ascii'|'utf8'|'utf16le'|'ucs2'(alias of 'utf16le')|'base64'|'base64url'|'binary'(deprecated)|'hex'

Annotations
@JSType() @native()
Linear Supertypes
Instantiable2[String, BufferEncoding, Buffer], Instantiable1[|[|[|[|[|[|[Any, Array[Any]], ArrayBuffer], Buffer], Double], String], Uint8Array], Buffer], StObject, Object, Any, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. BufferConstructor
  2. Instantiable2
  3. Instantiable1
  4. StObject
  5. Object
  6. Any
  7. AnyRef
  8. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def alloc(size: Double, fill: Unit, encoding: BufferEncoding): Buffer
  5. def alloc(size: Double, fill: Double, encoding: BufferEncoding): Buffer
  6. def alloc(size: Double, fill: Double): Buffer
  7. def alloc(size: Double, fill: String, encoding: BufferEncoding): Buffer
  8. def alloc(size: Double, fill: String): Buffer
  9. def alloc(size: Double, fill: Buffer, encoding: BufferEncoding): Buffer
  10. def alloc(size: Double, fill: Buffer): Buffer
  11. def alloc(size: Double): Buffer

    Allocates a new Buffer of size bytes.

    Allocates a new Buffer of size bytes. If fill is undefined, theBuffer will be zero-filled.

    js import { Buffer } from 'buffer';

    const buf = Buffer.alloc(5);

    console.log(buf); // Prints: <Buffer 00 00 00 00 00>

    If size is larger than constants.MAX_LENGTH or smaller than 0, ERR_INVALID_ARG_VALUE is thrown.

    If fill is specified, the allocated Buffer will be initialized by calling buf.fill(fill).

    js import { Buffer } from 'buffer';

    const buf = Buffer.alloc(5, 'a');

    console.log(buf); // Prints: <Buffer 61 61 61 61 61>

    If both fill and encoding are specified, the allocated Buffer will be initialized by calling buf.fill(fill, encoding).

    js import { Buffer } from 'buffer';

    const buf = Buffer.alloc(11, 'aGVsbG8gd29ybGQ=', 'base64');

    console.log(buf); // Prints: <Buffer 68 65 6c 6c 6f 20 77 6f 72 6c 64>

    Calling Buffer.alloc() can be measurably slower than the alternative Buffer.allocUnsafe() but ensures that the newly created Buffer instance contents will never contain sensitive data from previous allocations, including data that might not have been allocated for Buffers.

    A TypeError will be thrown if size is not a number.

    size

    The desired length of the new Buffer.

    Since

    v5.10.0

  12. def allocUnsafe(size: Double): Buffer

    Allocates a new Buffer of size bytes.

    Allocates a new Buffer of size bytes. If size is larger than constants.MAX_LENGTH or smaller than 0, ERR_INVALID_ARG_VALUE is thrown.

    The underlying memory for Buffer instances created in this way is _not_ _initialized_. The contents of the newly created Buffer are unknown and_may contain sensitive data_. Use Buffer.alloc() instead to initializeBuffer instances with zeroes.

    js import { Buffer } from 'buffer';

    const buf = Buffer.allocUnsafe(10);

    console.log(buf); // Prints (contents may vary): <Buffer a0 8b 28 3f 01 00 00 00 50 32>

    buf.fill(0);

    console.log(buf); // Prints: <Buffer 00 00 00 00 00 00 00 00 00 00>

    A TypeError will be thrown if size is not a number.

    The Buffer module pre-allocates an internal Buffer instance of size Buffer.poolSize that is used as a pool for the fast allocation of newBuffer instances created using Buffer.allocUnsafe(),Buffer.from(array), Buffer.concat(), and the deprecatednew Buffer(size) constructor only when size is less than or equal to Buffer.poolSize >> 1 (floor of Buffer.poolSize divided by two).

    Use of this pre-allocated internal memory pool is a key difference between calling Buffer.alloc(size, fill) vs. Buffer.allocUnsafe(size).fill(fill). Specifically, Buffer.alloc(size, fill) will _never_ use the internal Bufferpool, while Buffer.allocUnsafe(size).fill(fill)_will_ use the internalBuffer pool if size is less than or equal to half Buffer.poolSize. The difference is subtle but can be important when an application requires the additional performance that Buffer.allocUnsafe() provides.

    size

    The desired length of the new Buffer.

    Since

    v5.10.0

  13. def allocUnsafeSlow(size: Double): Buffer

    Allocates a new Buffer of size bytes.

    Allocates a new Buffer of size bytes. If size is larger than constants.MAX_LENGTH or smaller than 0, ERR_INVALID_ARG_VALUE is thrown. A zero-length Buffer is created if size is 0.

    The underlying memory for Buffer instances created in this way is _not_ _initialized_. The contents of the newly created Buffer are unknown and_may contain sensitive data_. Use buf.fill(0) to initialize such Buffer instances with zeroes.

    When using Buffer.allocUnsafe() to allocate new Buffer instances, allocations under 4 KB are sliced from a single pre-allocated Buffer. This allows applications to avoid the garbage collection overhead of creating many individually allocated Buffer instances. This approach improves both performance and memory usage by eliminating the need to track and clean up as many individual ArrayBuffer objects.

    However, in the case where a developer may need to retain a small chunk of memory from a pool for an indeterminate amount of time, it may be appropriate to create an un-pooled Buffer instance using Buffer.allocUnsafeSlow() and then copying out the relevant bits.

    js import { Buffer } from 'buffer';

    // Need to keep around a few small chunks of memory. const store = [];

    socket.on('readable', () => { let data; while (null !== (data = readable.read())) { // Allocate for retained data. const sb = Buffer.allocUnsafeSlow(10);

    // Copy the data into the new allocation. data.copy(sb, 0, 0, 10);

    store.push(sb); } });

    A TypeError will be thrown if size is not a number.

    size

    The desired length of the new Buffer.

    Since

    v5.12.0

  14. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  15. def byteLength(string: ArrayBuffer, encoding: BufferEncoding): Double
  16. def byteLength(string: ArrayBuffer): Double
  17. def byteLength(string: Any, encoding: BufferEncoding): Double
  18. def byteLength(string: Any): Double
  19. def byteLength(string: String, encoding: BufferEncoding): Double
  20. def byteLength(string: String): Double

    Returns the byte length of a string when encoded using encoding.

    Returns the byte length of a string when encoded using encoding. This is not the same as [String.prototype.length](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/length), which does not account for the encoding that is used to convert the string into bytes.

    For 'base64', 'base64url', and 'hex', this function assumes valid input. For strings that contain non-base64/hex-encoded data (e.g. whitespace), the return value might be greater than the length of a Buffer created from the string.

    js import { Buffer } from 'buffer';

    const str = '\\u00bd + \\u00bc = \\u00be';

    console.log(${str}: ${str.length} characters, + ${Buffer.byteLength(str, 'utf8')} bytes); // Prints: ½ + ¼ = ¾: 9 characters, 12 bytes

    When string is a Buffer/[DataView](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/DataView)/[TypedArray](https://developer.mozilla.org/en-US/docs/Web/JavaScript/- Reference/Global_Objects/TypedArray)/[ArrayBuffer](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer)/[SharedArrayBuffer](https://develop- er.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer), the byte length as reported by .byteLengthis returned.

    string

    A value to calculate the length of.

    returns

    The number of bytes contained within string.

    Since

    v0.1.90

  21. def byteLength(string: ArrayBufferView, encoding: BufferEncoding): Double
  22. def byteLength(string: ArrayBufferView): Double
  23. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native() @HotSpotIntrinsicCandidate()
  24. def compare(buf1: Uint8Array, buf2: Uint8Array): Double

    Compares buf1 to buf2, typically for the purpose of sorting arrays ofBuffer instances.

    Compares buf1 to buf2, typically for the purpose of sorting arrays ofBuffer instances. This is equivalent to calling buf1.compare(buf2).

    js import { Buffer } from 'buffer';

    const buf1 = Buffer.from('1234'); const buf2 = Buffer.from('0123'); const arr = [buf1, buf2];

    console.log(arr.sort(Buffer.compare)); // Prints: [ <Buffer 30 31 32 33>, <Buffer 31 32 33 34> ] // (This result is equal to: [buf2, buf1].)

    returns

    Either -1, 0, or 1, depending on the result of the comparison. See compare for details.

    Since

    v0.11.13

  25. def concat(list: Array[Uint8Array], totalLength: Double): Buffer
  26. def concat(list: Array[Uint8Array]): Buffer

    Returns a new Buffer which is the result of concatenating all the Bufferinstances in the list together.

    Returns a new Buffer which is the result of concatenating all the Bufferinstances in the list together.

    If the list has no items, or if the totalLength is 0, then a new zero-lengthBuffer is returned.

    If totalLength is not provided, it is calculated from the Buffer instances in list by adding their lengths.

    If totalLength is provided, it is coerced to an unsigned integer. If the combined length of the Buffers in list exceeds totalLength, the result is truncated to totalLength.

    js import { Buffer } from 'buffer';

    // Create a single Buffer from a list of three Buffer instances.

    const buf1 = Buffer.alloc(10); const buf2 = Buffer.alloc(14); const buf3 = Buffer.alloc(18); const totalLength = buf1.length + buf2.length + buf3.length;

    console.log(totalLength); // Prints: 42

    const bufA = Buffer.concat([buf1, buf2, buf3], totalLength);

    console.log(bufA); // Prints: <Buffer 00 00 00 00 ...> console.log(bufA.length); // Prints: 42

    Buffer.concat() may also use the internal Buffer pool like Buffer.allocUnsafe() does.

    list

    List of Buffer or Uint8Array instances to concatenate.

    Since

    v0.7.11

  27. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  28. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  29. def from(str: WithImplicitCoercion[String], encoding: BufferEncoding): Buffer
  30. def from(str: ToPrimitive, encoding: BufferEncoding): Buffer
  31. def from(str: ToPrimitive): Buffer
  32. def from(data: Uint8Array): Buffer

    Creates a new Buffer using the passed {data}

    Creates a new Buffer using the passed {data}

    data

    data to create a new Buffer

  33. def from(data: Array[Double]): Buffer
  34. def from(arrayBuffer: WithImplicitCoercion[|[ArrayBuffer, Any]], byteOffset: Unit, length: Double): Buffer
  35. def from(arrayBuffer: WithImplicitCoercion[|[ArrayBuffer, Any]], byteOffset: Double, length: Double): Buffer
  36. def from(arrayBuffer: WithImplicitCoercion[|[ArrayBuffer, Any]], byteOffset: Double): Buffer
  37. def from(arrayBuffer: WithImplicitCoercion[|[|[|[|[Any, Array[Double]], ArrayBuffer], String], Uint8Array]]): Buffer

    Creates a new Buffer containing the given JavaScript string {str}.

    Creates a new Buffer containing the given JavaScript string {str}. If provided, the {encoding} parameter identifies the character encoding. If not provided, {encoding} defaults to 'utf8'.

  38. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  39. def hasOwnProperty(v: String): Boolean
    Definition Classes
    Object
  40. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  41. def isBuffer(obj: Any): Boolean

    Returns true if obj is a Buffer, false otherwise.

    Returns true if obj is a Buffer, false otherwise.

    js import { Buffer } from 'buffer';

    Buffer.isBuffer(Buffer.alloc(10)); // true Buffer.isBuffer(Buffer.from('foo')); // true Buffer.isBuffer('a string'); // false Buffer.isBuffer([]); // false Buffer.isBuffer(new Uint8Array(1024)); // false

    Since

    v0.1.101

  42. def isEncoding(encoding: String): Boolean

    Returns true if encoding is the name of a supported character encoding, or false otherwise.

    Returns true if encoding is the name of a supported character encoding, or false otherwise.

    js import { Buffer } from 'buffer';

    console.log(Buffer.isEncoding('utf8')); // Prints: true

    console.log(Buffer.isEncoding('hex')); // Prints: true

    console.log(Buffer.isEncoding('utf/8')); // Prints: false

    console.log(Buffer.isEncoding()); // Prints: false

    encoding

    A character encoding name to check.

    Since

    v0.9.1

  43. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  44. def isPrototypeOf(v: Object): Boolean
    Definition Classes
    Object
  45. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  46. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  47. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @HotSpotIntrinsicCandidate()
  48. def of(items: Double*): Buffer

    Creates a new Buffer using the passed {data}

  49. val poolSize: Double

    This is the size (in bytes) of pre-allocated internal Buffer instances used for pooling.

    This is the size (in bytes) of pre-allocated internal Buffer instances used for pooling. This value may be modified.

    Since

    v0.11.3

  50. def propertyIsEnumerable(v: String): Boolean
    Definition Classes
    Object
  51. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  52. def toLocaleString(): String
    Definition Classes
    Object
  53. def toString(): String
    Definition Classes
    AnyRef → Any
  54. def valueOf(): Any
    Definition Classes
    Object
  55. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  56. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()
  57. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])

Deprecated Value Members

  1. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable]) @Deprecated
    Deprecated

Inherited from Instantiable2[String, BufferEncoding, Buffer]

Inherited from Instantiable1[|[|[|[|[|[|[Any, Array[Any]], ArrayBuffer], Buffer], Double], String], Uint8Array], Buffer]

Inherited from StObject

Inherited from Object

Inherited from Any

Inherited from AnyRef

Inherited from Any

Ungrouped