buffer3 内容: 编程三昧 bianchengsanmei



Node.js klassische Puffertechnik (Zusammenfassungsfreigabe)
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.
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()
var buf = new Buffer('bianchengsanmei'); var json = buf.toJSON(buf); console.log(json);
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 ] }
Nach dem Login kopieren
{ 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])
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());
Syntax
Die Funktionssyntax des Knotenpuffervergleichs lautet wie folgt. Diese Methode wurde in Node.js v0 eingeführt .12.2 Version:buffer3 内容: 编程三昧 bianchengsanmei
Nach dem Login kopieren
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
otherBuffer identisch ist.
Instanz
buf.compare(otherBuffer);
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 + "之后");}
Syntax für die Knotenpufferkopie lautet wie folgt:
ABC在ABCD之前
Die Parameter werden beschrieben wie folgt:
targetBuffer – das zu kopierende Buffer-Objekt. targetStart – Zahl, optional, Standard: 0sourceStart – 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());
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!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Wie packe ich die ausführbare Datei von nodejs mit pkg? Im folgenden Artikel erfahren Sie, wie Sie mit pkg ein Node-Projekt in eine ausführbare Datei packen. Ich hoffe, dass er Ihnen weiterhilft!
