Heim >Web-Frontend >js-Tutorial >Ein genauerer Blick auf Puffer in Node.js

Ein genauerer Blick auf Puffer in Node.js

青灯夜游
青灯夜游nach vorne
2022-01-27 18:27:202360Durchsuche

Dieser Artikel vermittelt Ihnen ein tiefgreifendes Verständnis von Buffer in Node.js. Er stellt verschiedene Möglichkeiten zum Erstellen der Buffer-Klasse, Methoden zum Schreiben in Puffer usw. vor. Ich hoffe, er wird Ihnen hilfreich sein!

Ein genauerer Blick auf Puffer in Node.js

Die JavaScript-Sprache selbst hat nur String-Datentypen, keine binären Datentypen.

Aber bei der Verarbeitung von Streams wie TCP oder Dateistreams müssen Binärdaten verwendet werden. Daher ist in Node.js eine Buffer-Klasse definiert, mit der ein Pufferbereich speziell zum Speichern von Binärdaten erstellt wird.

In Node.js ist die Buffer-Klasse eine Kernbibliothek, die mit dem Node-Kernel veröffentlicht wird. Die Buffer-Bibliothek bietet eine Methode zum Speichern von Rohdaten in Node.js und ermöglicht es Node.js, Binärdaten zu verarbeiten. Wann immer Sie während E/A-Vorgängen in Node.js verschobene Daten verarbeiten müssen, ist es möglich, die Buffer-Bibliothek zu verwenden. .

Die Originaldaten werden in einer Instanz der Buffer-Klasse gespeichert.

Ein Puffer ähnelt einem ganzzahligen Array, entspricht jedoch einem Teil des Rohspeichers außerhalb des V8-Heapspeichers.

Erstellen Sie die Buffer-Klasse

Die Node Buffer-Klasse kann auf verschiedene Arten erstellt werden.

Methode 1

Erstellen Sie eine Pufferinstanz mit einer Länge von 10 Bytes:

var buf = new Buffer(10);

Methode 2

Erstellen Sie eine Pufferinstanz aus dem angegebenen Array:

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

Methode 3

Übergeben Sie eine Zeichenfolge. Erstellen eine Pufferinstanz:

var buf = new Buffer("bianchengsanmei", "utf-8");

utf-8 ist die Standardkodierung und unterstützt auch die folgenden Kodierungen: „ascii“, „utf8“, „utf16le“, „ucs2“, „base64“ und „hex“.

Puffer schreiben

Syntax

Die Syntax zum Schreiben des Knotenpuffers lautet wie folgt:

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

Parameter

Die Parameter werden wie folgt beschrieben:

  • String – die in den Puffer geschriebene Zeichenfolge.
  • Offset – Der Indexwert, bei dem mit dem Schreiben des Puffers begonnen wird. Der Standardwert ist 0 .
  • length – Anzahl der geschriebenen Bytes, standardmäßig buffer.length
  • encoding – Verwendete Codierung. Standardmäßig ist „utf8“ .

Rückgabewert

Gibt die tatsächliche Schriftgröße zurück. Wenn nicht genügend Pufferspeicher vorhanden ist, wird nur ein Teil der Zeichenfolge geschrieben.
Instanz

buf = new Buffer(256);
len = buf.write("bi");
len = buf.write("bianchengsanmei"); 
console.log("写入字节数 : "+  len);

Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:

$node main.js
写入字节数 : 15

Daten aus dem Puffer lesen

Syntax

Die Syntax zum Lesen von Knotenpufferdaten lautet wie folgt:

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

Parameter

Die Parameter werden wie folgt beschrieben:

  • Kodierung – die verwendete Kodierung. Standardmäßig ist „utf8“ .

  • start – Gibt die Indexposition an, an der mit dem Lesen begonnen werden soll. Der Standardwert ist 0.

  • end – Endposition, standardmäßig das Ende des Puffers.

Rückgabewert

Dekodieren Sie die Pufferdaten und geben Sie eine Zeichenfolge mit der angegebenen Kodierung zurück.

Instanz

buf = new Buffer(26);
for (var i = 0 ; i < 26 ; i++) {
  buf[i] = i + 97;
}
 
console.log( buf.toString(&#39;ascii&#39;));       // 输出: abcdefghijklmnopqrstuvwxyz
console.log( buf.toString(&#39;ascii&#39;,0,5));   // 输出: abcde
console.log( buf.toString(&#39;utf8&#39;,0,5));    // 输出: abcde
console.log( buf.toString(undefined,0,5)); // 使用 &#39;utf8&#39; 编码, 并输出: abcde

Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:

$ node main.js
abcdefghijklmnopqrstuvwxyz
abcde
abcde
abcde

Konvertieren Sie den Puffer in ein JSON-Objekt e

Return Der Wert

gibt ein JSON-Objekt zurück.

Instanz

buf.toJSON()

Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:

var buf = new Buffer(&#39;bianchengsanmei&#39;);
var json = buf.toJSON(buf);
 
console.log(json);

Pufferzusammenführung

Syntax

Knoten Die Syntax der Pufferzusammenführung lautet wie folgt:

{
  type: &#39;Buffer&#39;,
  data: [
     98, 105, 97, 110, 99, 104, 101, 110, 103, 115, 97, 110, 109, 101, 105
  ]
}

Parameter

Die Parameter werden wie folgt beschrieben:

list – Array-Liste von Pufferobjekten, die zum Zusammenführen verwendet werden. totalLength – Gibt die Gesamtlänge der zusammengeführten Buffer-Objekte an.

    Rückgabewert
  • Gibt ein neues Pufferobjekt zurück, das mehrere Mitglieder kombiniert.

Instanz

Buffer.concat(list[, totalLength])

Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:

var buffer1 = new Buffer(&#39;编程三昧 &#39;);
var buffer2 = new Buffer(&#39;bi&#39;);
var buffer2 = new Buffer(&#39;bianchengsanmei&#39;);
var buffer3 = Buffer.concat([buffer1,buffer2]);
console.log("buffer3 内容: " + buffer3.toString());

Puffervergleich

Syntax

Die Funktionssyntax des Knotenpuffervergleichs lautet wie folgt. Diese Methode wurde in Node.js v0 eingeführt .12.2 Version:

buffer3 内容: 编程三昧 bianchengsanmei

Parameter

Parameter werden wie folgt beschrieben:

otherBuffer – ein weiteres Buffer-Objekt im Vergleich zum

buf

-Objekt.

  • RückgabewertGibt eine Zahl zurück, die angibt, dass
  • buf
vor, nach oder mit

otherBuffer identisch ist.

Instanz

buf.compare(otherBuffer);
Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:
var buffer1 = new Buffer(&#39;ABC&#39;);
var buffer2 = new Buffer(&#39;ABCD&#39;);
var result = buffer1.compare(buffer2);
 
if(result < 0) {
   console.log(buffer1 + " 在 " + buffer2 + "之前");
}else if(result == 0){
   console.log(buffer1 + " 与 " + buffer2 + "相同");
}else {
   console.log(buffer1 + " 在 " + buffer2 + "之后");
}

Puffer kopieren

Syntax

Die Syntax für das Kopieren des Knotenpuffers lautet wie folgt:

ABC在ABCD之前

Parameter

Die Parameter werden beschrieben wie folgt:

targetBuffer – das zu kopierende Buffer-Objekt. targetStart – Zahl, optional, Standard: 0

sourceStart – Zahl, optional, Standard: 0

    sourceEnd – Zahl, optional, Standard: buffer.length
  • Rückgabewert
  • Kein Rückgabewert.

Instanz

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

Führen Sie den obigen Code aus. Das Ausgabeergebnis lautet:

buffer2 content: ABC

缓冲区裁剪

Node 缓冲区裁剪语法如下所示:

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

参数

参数描述如下:

  • start - 数字, 可选, 默认: 0
  • end - 数字, 可选, 默认: buffer.length

返回值

返回一个新的缓冲区,它和旧缓冲区指向同一块内存,但是从索引 start 到 end 的位置剪切。

实例

var buffer1 = new Buffer(&#39;youj&#39;);
// 剪切缓冲区
var buffer2 = buffer1.slice(0,2);
console.log("buffer2 content: " + buffer2.toString());

执行以上代码,输出结果为:

buffer2 content: yo

缓冲区长度

语法 Node 缓冲区长度计算语法如下所示:

buf.length;

返回值

返回 Buffer 对象所占据的内存长度。

实例

var buffer = new Buffer(&#39;bianchengsanmei&#39;);
//  缓冲区长度
console.log("buffer length: " + buffer.length);

执行以上代码,输出结果为:

buffer length: 15

~

~本文完,感谢阅读!

更多node相关知识,请访问:nodejs 教程

Das obige ist der detaillierte Inhalt vonEin genauerer Blick auf Puffer in Node.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:juejin.cn. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen