Heim >Web-Frontend >Front-End-Fragen und Antworten >Node.js klassische Puffertechnik (Zusammenfassungsfreigabe)

Node.js klassische Puffertechnik (Zusammenfassungsfreigabe)

WBOY
WBOYnach vorne
2022-02-18 17:31:242330Durchsuche

Dieser Artikel vermittelt Ihnen relevantes Wissen über Buffer in nodejs In Node.js ist die Buffer-Klasse eine Kernbibliothek, die mit dem Node-Kernel veröffentlicht wird. Ich hoffe, dass die Buffer-Bibliothek eine primitive Speichermethode für Node.js-Datenmethoden darstellt wird für alle hilfreich sein.

Node.js klassische Puffertechnik (Zusammenfassungsfreigabe)

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. Der Standardwert 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. Der Standardwert 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('ascii'));       
 // 输出: abcdefghijklmnopqrstuvwxyzconsole.log( buf.toString('ascii',0,5));   
 // 输出: abcdeconsole.log( buf.toString('utf8',0,5));    
 // 输出: abcdeconsole.log( buf.toString(undefined,0,5)); 
 // 使用 'utf8' 编码, 并输出: 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('bianchengsanmei');
var json = buf.toJSON(buf);
 console.log(json);
Pufferzusammenführung

Syntax

Knoten Die Syntax der Pufferzusammenführung lautet wie folgt:

{ type: 'Buffer',
  data: [ 119, 119, 119, 46, 119, 51, 99, 115, 99, 104, 111, 111, 108, 46, 99, 110 ] }

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('编程三昧 ');
var buffer2 = new Buffer('bi');
var buffer2 = new Buffer('bianchengsanmei');
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('ABC');var buffer2 = new Buffer('ABCD');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 für die Knotenpufferkopie 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:

var buffer1 = new Buffer('ABC');
// 拷贝一个缓冲区var buffer2 = new Buffer(3);
buffer1.copy(buffer2);
console.log("buffer2 content: " + buffer2.toString());
Puffer-Clipping

Die Knotenpuffer-Clipping-Syntax lautet wie folgt:

buffer2 content: ABC

Parameter

Die Parameter werden wie folgt beschrieben:

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

返回值

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

实例

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

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

buffer2 content: yo

缓冲区长度

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

buf.length;

返回值

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

实例

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

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

buffer length: 15

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

Das obige ist der detaillierte Inhalt vonNode.js klassische Puffertechnik (Zusammenfassungsfreigabe). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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