Node.js - Puffer

Reines JavaScript ist Unicode-freundlich, bei Binärdaten jedoch nicht. Beim Umgang mit TCP-Streams oder dem Dateisystem müssen Oktett-Streams verarbeitet werden. Der Knoten stellt eine Pufferklasse bereit, die Instanzen zum Speichern von Rohdaten bereitstellt, die einem Array von Ganzzahlen ähneln, jedoch einer Rohspeicherzuordnung außerhalb des V8-Heaps entsprechen.

Die Pufferklasse ist eine globale Klasse, auf die in einer Anwendung zugegriffen werden kann, ohne das Puffermodul zu importieren.

Puffer erstellen

Der Knotenpuffer kann auf verschiedene Arten aufgebaut werden.

Methode 1

Im Folgenden finden Sie die Syntax zum Erstellen eines nicht initiierten Puffers von 10 Oktette -

var buf = new Buffer(10);

Methode 2

Es folgt die Syntax zum Erstellen eines Puffers aus einem bestimmten Array:

var buf = new Buffer([10, 20, 30, 40, 50]);

Methode 3

Es folgt die Syntax zum Erstellen eines Puffers aus einer bestimmten Zeichenfolge und optional einem Codierungstyp:

var buf = new Buffer("Simply Easy Learning", "utf-8");

Obwohl "utf8" die Standardcodierung ist, können Sie eine der folgenden Codierungen verwenden: "ascii", "utf8", "utf16le", "ucs2", "base64" oder "hex".

Schreiben an Puffer

Syntax

Es folgt die Syntax der Methode zum Schreiben in einen Knotenpuffer -

buf.write(string[, offset][, length][, encoding])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • string - Dies sind die Zeichenfolgendaten, die in den Puffer geschrieben werden sollen.

  • offset- Dies ist der Index des Puffers, bei dem mit dem Schreiben begonnen werden soll. Der Standardwert ist 0.

  • length- Dies ist die Anzahl der zu schreibenden Bytes. Der Standardwert ist buffer.length.

  • encoding- Zu verwendende Codierung. 'utf8' ist die Standardcodierung.

Rückgabewert

Diese Methode gibt die Anzahl der geschriebenen Oktette zurück. Wenn im Puffer nicht genügend Speicherplatz für die gesamte Zeichenfolge vorhanden ist, wird ein Teil der Zeichenfolge geschrieben.

Beispiel

buf = new Buffer(256);
len = buf.write("Simply Easy Learning");

console.log("Octets written : "+  len);

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

Octets written : 20

Lesen aus Puffern

Syntax

Es folgt die Syntax der Methode zum Lesen von Daten aus einem Knotenpuffer -

buf.toString([encoding][, start][, end])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • encoding- Zu verwendende Codierung. 'utf8' ist die Standardcodierung.

  • start - Beginn des Index zum Starten des Lesens, standardmäßig 0.

  • end - Index beenden, um das Lesen zu beenden, Standard ist der vollständige Puffer.

Rückgabewert

Diese Methode decodiert und gibt eine Zeichenfolge aus Pufferdaten zurück, die mit der angegebenen Zeichensatzcodierung codiert wurden.

Beispiel

buf = new Buffer(26);
for (var i = 0 ; i < 26 ; i++) {
  buf[i] = i + 97;
}

console.log( buf.toString('ascii'));       // outputs: abcdefghijklmnopqrstuvwxyz
console.log( buf.toString('ascii',0,5));   // outputs: abcde
console.log( buf.toString('utf8',0,5));    // outputs: abcde
console.log( buf.toString(undefined,0,5)); // encoding defaults to 'utf8', outputs abcde

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

abcdefghijklmnopqrstuvwxyz
abcde
abcde
abcde

Puffer in JSON konvertieren

Syntax

Es folgt die Syntax der Methode zum Konvertieren eines Knotenpuffers in ein JSON-Objekt:

buf.toJSON()

Rückgabewert

Diese Methode gibt eine JSON-Darstellung der Pufferinstanz zurück.

Beispiel

var buf = new Buffer('Simply Easy Learning');
var json = buf.toJSON(buf);

console.log(json);

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

{ type: 'Buffer',
   data: 
   [ 
      83,
      105,
      109,
      112,
      108,
      121,
      32,
      69,
      97,
      115,
      121,
      32,
      76,
      101,
      97,
      114,
      110,
      105,
      110,
      103 
   ]
}

Puffer verketten

Syntax

Es folgt die Syntax der Methode zum Verketten von Knotenpuffern zu einem einzelnen Knotenpuffer -

Buffer.concat(list[, totalLength])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • list - Array Liste der zu verkettenden Pufferobjekte.

  • totalLength - Dies ist die Gesamtlänge der Puffer bei Verkettung.

Rückgabewert

Diese Methode gibt eine Pufferinstanz zurück.

Beispiel

var buffer1 = new Buffer('TutorialsPoint ');
var buffer2 = new Buffer('Simply Easy Learning');
var buffer3 = Buffer.concat([buffer1,buffer2]);

console.log("buffer3 content: " + buffer3.toString());

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

buffer3 content: TutorialsPoint Simply Easy Learning

Puffer vergleichen

Syntax

Es folgt die Syntax der Methode zum Vergleichen zweier Knotenpuffer:

buf.compare(otherBuffer);

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • otherBuffer - Dies ist der andere Puffer, mit dem verglichen wird buf

Rückgabewert

Gibt eine Zahl zurück, die angibt, ob sie vor oder nach dem anderen Puffer in Sortierreihenfolge steht oder mit diesem identisch ist.

Beispiel

var buffer1 = new Buffer('ABC');
var buffer2 = new Buffer('ABCD');
var result = buffer1.compare(buffer2);

if(result < 0) {
   console.log(buffer1 +" comes before " + buffer2);
} else if(result === 0) {
   console.log(buffer1 +" is same as " + buffer2);
} else {
   console.log(buffer1 +" comes after " + buffer2);
}

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

ABC comes before ABCD

Puffer kopieren

Syntax

Es folgt die Syntax der Methode zum Kopieren eines Knotenpuffers:

buf.copy(targetBuffer[, targetStart][, sourceStart][, sourceEnd])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • targetBuffer - Pufferobjekt, in das der Puffer kopiert wird.

  • targetStart - Nummer, Optional, Standard: 0

  • sourceStart - Nummer, Optional, Standard: 0

  • sourceEnd - Nummer, Optional, Standard: buffer.length

Rückgabewert

Kein Rückgabewert. Kopiert Daten aus einem Bereich dieses Puffers in einen Bereich im Zielpuffer, selbst wenn sich der Zielspeicherbereich mit der Quelle überlappt. Wenn nicht definiert, sind die Parameter targetStart und sourceStart standardmäßig 0, während sourceEnd standardmäßig buffer.length ist.

Beispiel

var buffer1 = new Buffer('ABC');

//copy a buffer
var buffer2 = new Buffer(3);
buffer1.copy(buffer2);
console.log("buffer2 content: " + buffer2.toString());

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

buffer2 content: ABC

Scheibenpuffer

Syntax

Es folgt die Syntax der Methode zum Abrufen eines Unterpuffers eines Knotenpuffers:

buf.slice([start][, end])

Parameter

Hier ist die Beschreibung der verwendeten Parameter -

  • start - Nummer, Optional, Standard: 0

  • end - Nummer, Optional, Standard: buffer.length

Rückgabewert

Gibt einen neuen Puffer zurück, der auf denselben Speicher wie der alte verweist, jedoch durch die Indizes start (standardmäßig 0) und end (standardmäßig buffer.length) versetzt und beschnitten wird. Negative Indizes beginnen am Ende des Puffers.

Beispiel

var buffer1 = new Buffer('TutorialsPoint');

//slicing a buffer
var buffer2 = buffer1.slice(0,9);
console.log("buffer2 content: " + buffer2.toString());

Wenn das obige Programm ausgeführt wird, erzeugt es das folgende Ergebnis:

buffer2 content: Tutorials

Pufferlänge

Syntax

Es folgt die Syntax der Methode zum Abrufen der Größe eines Knotenpuffers in Byte -

buf.length;

Rückgabewert

Gibt die Größe eines Puffers in Bytes zurück.

Beispiel

var buffer = new Buffer('TutorialsPoint');

//length of the buffer
console.log("buffer length: " + buffer.length);

Wenn das obige Programm ausgeführt wird, erzeugt es folgendes Ergebnis:

buffer length: 14

Methodenreferenz

Sr.Nr. Methode & Beschreibung
1

new Buffer(size)

Weist einen neuen Puffer mit Oktetten zu. Beachten Sie, dass die Größe nicht mehr als kMaxLength betragen darf. Andernfalls wird hier ein RangeError ausgelöst.

2

new Buffer(buffer)

Kopiert die übergebenen Pufferdaten auf eine neue Pufferinstanz.

3

new Buffer(str[, encoding])

Weist einen neuen Puffer zu, der die angegebene str enthält. Die Codierung ist standardmäßig 'utf8'.

4

buf.length

Gibt die Größe des Puffers in Bytes zurück. Beachten Sie, dass dies nicht unbedingt die Größe des Inhalts ist. Länge bezieht sich auf die für das Pufferobjekt zugewiesene Speichermenge. Es ändert sich nicht, wenn der Inhalt des Puffers geändert wird.

5

buf.write(string[, offset][, length][, encoding])

Schreibt eine Zeichenfolge mit Versatz unter Verwendung der angegebenen Codierung in den Puffer. Der Standardwert für den Offset ist 0, für die Codierung standardmäßig 'utf8'. Länge ist die Anzahl der zu schreibenden Bytes. Gibt die Anzahl der geschriebenen Oktette zurück.

6

buf.writeUIntLE(value, offset, byteLength[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset und der angegebenen Bytelänge in den Puffer. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Der Standardwert ist false.

7

buf.writeUIntBE(value, offset, byteLength[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset und der angegebenen Bytelänge in den Puffer. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Der Standardwert ist false.

8

buf.writeIntLE(value, offset, byteLength[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset und der angegebenen Bytelänge in den Puffer. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Der Standardwert ist false.

9

buf.writeIntBE(value, offset, byteLength[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset und der angegebenen Bytelänge in den Puffer. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Der Standardwert ist false.

10

buf.readUIntLE(offset, byteLength[, noAssert])

Eine verallgemeinerte Version aller numerischen Lesemethoden. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

11

buf.readUIntBE(offset, byteLength[, noAssert])

Eine verallgemeinerte Version aller numerischen Lesemethoden. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

12

buf.readIntLE(offset, byteLength[, noAssert])

Eine verallgemeinerte Version aller numerischen Lesemethoden. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

13

buf.readIntBE(offset, byteLength[, noAssert])

Eine verallgemeinerte Version aller numerischen Lesemethoden. Unterstützt bis zu 48 Bit Genauigkeit. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

14

buf.toString([encoding][, start][, end])

Dekodiert und gibt eine Zeichenfolge aus Pufferdaten zurück, die mit der angegebenen Zeichensatzcodierung codiert wurden.

15

buf.toJSON()

Gibt eine JSON-Darstellung der Buffer-Instanz zurück. JSON.stringify ruft diese Funktion implizit auf, wenn eine Pufferinstanz stringifiziert wird.

16

buf[index]

Holen Sie sich das Oktett und setzen Sie es auf den Index. Die Werte beziehen sich auf einzelne Bytes, sodass der zulässige Bereich zwischen 0x00 und 0xFF hex oder 0 und 255 liegt.

17

buf.equals(otherBuffer)

Gibt einen Booleschen Wert zurück, wenn dieser Puffer und otherBuffer dieselben Bytes haben.

18

buf.compare(otherBuffer)

Gibt eine Zahl zurück, die angibt, ob dieser Puffer vor oder nach dem Puffer steht oder mit dem anderen Puffer in Sortierreihenfolge identisch ist.

19

buf.copy(targetBuffer[, targetStart][, sourceStart][, sourceEnd])

Kopiert Daten aus einem Bereich dieses Puffers in einen Bereich im Zielpuffer, selbst wenn sich der Zielspeicherbereich mit der Quelle überlappt. Wenn nicht definiert, sind die Parameter targetStart und sourceStart standardmäßig 0, während sourceEnd standardmäßig buffer.length ist.

20

buf.slice([start][, end])

Gibt einen neuen Puffer zurück, der auf denselben Speicher wie der alte verweist, jedoch durch die Indizes start (standardmäßig 0) und end (standardmäßig buffer.length) versetzt und beschnitten wird. Negative Indizes beginnen am Ende des Puffers.

21

buf.readUInt8(offset[, noAssert])

Liest eine vorzeichenlose 8-Bit-Ganzzahl mit dem angegebenen Offset aus dem Puffer. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

22

buf.readUInt16LE(offset[, noAssert])

Liest eine vorzeichenlose 16-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

23

buf.readUInt16BE(offset[, noAssert])

Liest eine vorzeichenlose 16-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

24

buf.readUInt32LE(offset[, noAssert])

Liest eine vorzeichenlose 32-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

25

buf.readUInt32BE(offset[, noAssert])

Liest eine vorzeichenlose 32-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

26

buf.readInt8(offset[, noAssert])

Liest eine vorzeichenbehaftete 8-Bit-Ganzzahl mit dem angegebenen Offset aus dem Puffer. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

27

buf.readInt16LE(offset[, noAssert])

Liest eine vorzeichenbehaftete 16-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

28

buf.readInt16BE(offset[, noAssert])

Liest eine vorzeichenbehaftete 16-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

29

buf.readInt32LE(offset[, noAssert])

Liest eine vorzeichenbehaftete 32-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

30

buf.readInt32BE(offset[, noAssert])

Liest eine vorzeichenbehaftete 32-Bit-Ganzzahl aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

31

buf.readFloatLE(offset[, noAssert])

Liest einen 32-Bit-Float mit dem angegebenen Offset und dem angegebenen Endian-Format aus dem Puffer. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

32

buf.readFloatBE(offset[, noAssert])

Liest einen 32-Bit-Float mit dem angegebenen Offset und dem angegebenen Endian-Format aus dem Puffer. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

33

buf.readDoubleLE(offset[, noAssert])

Liest ein 64-Bit-Double aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

34

buf.readDoubleBE(offset[, noAssert])

Liest ein 64-Bit-Double aus dem Puffer mit dem angegebenen Offset und dem angegebenen Endian-Format. Setzen Sie noAssert auf true, um die Validierung des Offsets zu überspringen. Dies bedeutet, dass der Versatz möglicherweise über dem Ende des Puffers liegt. Der Standardwert ist false.

35

buf.writeUInt8(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Versatz in den Puffer. Beachten Sie, dass der Wert eine gültige 8-Bit-Ganzzahl ohne Vorzeichen sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert möglicherweise zu groß für die spezifische Funktion ist und der Versatz über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

36

buf.writeUInt16LE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenlose 16-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich der Richtigkeit sicher. Der Standardwert ist false.

37

buf.writeUInt16BE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenlose 16-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

38

buf.writeUInt32LE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige 32-Bit-Ganzzahl ohne Vorzeichen sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

39

buf.writeUInt32BE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige 32-Bit-Ganzzahl ohne Vorzeichen sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

40

buf.writeInt8(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenbehaftete 8-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

41

buf.writeInt16LE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenbehaftete 16-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

42

buf.writeInt16BE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenbehaftete 16-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert möglicherweise zu groß für die spezifische Funktion ist und der Versatz über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

43

buf.writeInt32LE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenbehaftete 32-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

44

buf.writeInt32BE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert eine gültige vorzeichenbehaftete 32-Bit-Ganzzahl sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich der Richtigkeit sicher. Der Standardwert ist false.

45

buf.writeFloatLE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert ein gültiger 32-Bit-Float sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert möglicherweise zu groß für die spezifische Funktion ist und der Versatz über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

46

buf.writeFloatBE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert ein gültiger 32-Bit-Float sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

47

buf.writeDoubleLE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert ein gültiges 64-Bit-Double sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

48

buf.writeDoubleBE(value, offset[, noAssert])

Schreibt einen Wert mit dem angegebenen Offset mit dem angegebenen Endian-Format in den Puffer. Beachten Sie, dass der Wert ein gültiges 64-Bit-Double sein muss. Setzen Sie noAssert auf true, um die Validierung von Wert und Offset zu überspringen. Dies bedeutet, dass der Wert für die spezifische Funktion möglicherweise zu groß ist und der Versatz möglicherweise über das Ende des Puffers hinausgeht, was dazu führt, dass die Werte stillschweigend gelöscht werden. Es sollte nicht verwendet werden, es sei denn, Sie sind sich seiner Richtigkeit sicher. Der Standardwert ist false.

49

buf.fill(value[, offset][, end])

Füllt den Puffer mit dem angegebenen Wert. Wenn der Offset (standardmäßig 0) und das Ende (standardmäßig buffer.length) nicht angegeben sind, wird der gesamte Puffer gefüllt.

Klassenmethoden

Sr.Nr. Methode & Beschreibung
1

Buffer.isEncoding(encoding)

Gibt true zurück, wenn die Codierung ein gültiges Codierungsargument ist, andernfalls false.

2

Buffer.isBuffer(obj)

Testet, ob obj ein Puffer ist.

3

Buffer.byteLength(string[, encoding])

Gibt die tatsächliche Bytelänge eines Strings an. Die Codierung ist standardmäßig 'utf8'. Es ist nicht dasselbe wie String.prototype.length, da String.prototype.length die Anzahl der Zeichen in einem String zurückgibt.

4

Buffer.concat(list[, totalLength])

Gibt einen Puffer zurück, der das Ergebnis der Verkettung aller Puffer in der Liste ist.

5

Buffer.compare(buf1, buf2)

Das gleiche wie buf1.compare (buf2). Nützlich zum Sortieren einer Reihe von Puffern.