Inhaltsverzeichnis
Zeichensatz
Pufferkodierung von Node.js
Quellcode kodieren
Zusammenfassung
Heim Web-Frontend js-Tutorial Lassen Sie uns über die Codierung im Node.js-Puffer sprechen

Lassen Sie uns über die Codierung im Node.js-Puffer sprechen

Aug 31, 2021 am 10:28 AM
buffer encoding node.js

Dieser Artikel führt Sie durch die Codierung in Node.js Buffer. Ich hoffe, er wird Ihnen helfen!

Lassen Sie uns über die Codierung im Node.js-Puffer sprechen

Die kleinste Einheit eines Computers ist ein Bit, also 0 und 1, die hohen und niedrigen Pegeln der Hardware entsprechen. Da jedoch nur ein Bit zu wenig Informationen darstellt, werden 8 Bits als ein Byte angegeben. Danach werden verschiedene Informationen wie Zahlen und Zeichenfolgen auf Basis von Bytes gespeichert. [Empfohlenes Lernen: „nodejs-Tutorial“] Wie speichere ich

Zeichen? Es basiert auf der Kodierung. Wenn dann ein Rendern erforderlich ist, wird die Schriftartenbibliothek entsprechend der entsprechenden Kodierung überprüft und anschließend werden die Grafiken der entsprechenden Zeichen gerendert.

Zeichensatz

Der früheste Zeichensatz (Zeichensatz) ist der ASCII-Code, der aus ABC 123 und weiteren 128 Zeichen besteht, da der Computer erstmals in den Vereinigten Staaten erfunden wurde. Später entwickelte Europa auch eine Reihe von Zeichensatzstandards namens ISO, und später entwickelte China auch eine Reihe von Zeichensatzstandards namens GBK.

Die Internationale Organisation für Normung war der Meinung, dass nicht jeder von uns einen anderen Code haben könne, da sonst derselbe Code in verschiedenen Zeichensätzen unterschiedliche Bedeutungen hätte. Deshalb haben wir eine Unicode-Codierung vorgeschlagen, die die meisten Codes der Welt einschließt, sodass jedes Zeichen eine hat ein einzigartiger Code.

Aber ASCII-Code erfordert nur 1 Byte zum Speichern, während GBK 2 Bytes erfordert und einige Zeichensätze 3 Bytes erfordern usw. Einige benötigen nur ein Byte zum Speichern, aber 2 Bytes sind eine ziemliche Platzverschwendung. Es gibt also verschiedene Kodierungsschemata wie utf-8, utf-16, utf-24 usw.

utf-8, utf-16 und utf-24 sind alles Unicode-Kodierungen, aber die spezifischen Implementierungspläne sind unterschiedlich.

UTF-8 Um Platz zu sparen, wurde eine Speicherlösung mit variabler Länge von 1 bis 6 Bytes entwickelt. UTF-16 ist auf 2 Bytes festgelegt und UTF-24 ist auf 4 Bytes festgelegt.

Lassen Sie uns über die Codierung im Node.js-Puffer sprechen

Schließlich wird UTF-8 häufig verwendet, da es am wenigsten Platz beansprucht.

Pufferkodierung von Node.js

Jede Sprache unterstützt die Kodierung und Dekodierung von Zeichensätzen, und Node.js macht dasselbe.

Buffer kann zum Speichern von Binärdaten in Node.js verwendet werden. Beim Konvertieren von Binärdaten in eine Zeichenfolge müssen Sie den Zeichensatz from, byteLength, lastIndexOf und andere Methoden angeben, die die Angabe der Codierung unterstützen:

Spezifische Unterstützung Die Codierungen umfassen:

utf8, ucs2, utf16le, latin1, ascii, base64, hex

Einige Schüler finden möglicherweise: base64 und hex sind keine Zeichensätze. Warum erscheinen sie hier?

Ja, zusätzlich zu Zeichensätzen umfassen Byte-zu-Zeichen-Codierungsschemata auch Base64 für die Konvertierung in Klartextzeichen und Hex für die Konvertierung in Hexadezimalzeichen.

Aus diesem Grund nennt Node.js es Codierung statt Zeichensatz, da es sich bei den unterstützten Codierungs- und Decodierungsschemata nicht nur um Zeichensätze handelt.

Wenn keine Kodierung angegeben ist, ist die Standardeinstellung utf8.

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

console.log(buf.toString());// hello world
Nach dem Login kopieren

Quellcode kodieren

Ich habe den Node.js-Quellcode zur Kodierung durchgesehen:

Dieser Abschnitt implementiert die Kodierung: https://github.com/nodejs/node/blob/master/lib/ buffer.js #L587-L726

Sie können sehen, dass jede Codierung die APIs „Encoding“, „EncodingVal“, „ByteLength“, „Write“, „Slice“ und „IndexOf“ implementiert. Da diese APIs unterschiedliche Codierungsschemata verwenden, liefern sie unterschiedliche Ergebnisse die eingehende Kodierung, die eine polymorphe Idee ist.

const encodingOps = {
  utf8: {
    encoding: 'utf8',
    encodingVal: encodingsMap.utf8,
    byteLength: byteLengthUtf8,
    write: (buf, string, offset, len) => buf.utf8Write(string, offset, len),
    slice: (buf, start, end) => buf.utf8Slice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfString(buf, val, byteOffset, encodingsMap.utf8, dir)
  },
  ucs2: {
    encoding: 'ucs2',
    encodingVal: encodingsMap.utf16le,
    byteLength: (string) => string.length * 2,
    write: (buf, string, offset, len) => buf.ucs2Write(string, offset, len),
    slice: (buf, start, end) => buf.ucs2Slice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfString(buf, val, byteOffset, encodingsMap.utf16le, dir)
  },
  utf16le: {
    encoding: 'utf16le',
    encodingVal: encodingsMap.utf16le,
    byteLength: (string) => string.length * 2,
    write: (buf, string, offset, len) => buf.ucs2Write(string, offset, len),
    slice: (buf, start, end) => buf.ucs2Slice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfString(buf, val, byteOffset, encodingsMap.utf16le, dir)
  },
  latin1: {
    encoding: 'latin1',
    encodingVal: encodingsMap.latin1,
    byteLength: (string) => string.length,
    write: (buf, string, offset, len) => buf.latin1Write(string, offset, len),
    slice: (buf, start, end) => buf.latin1Slice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfString(buf, val, byteOffset, encodingsMap.latin1, dir)
  },
  ascii: {
    encoding: 'ascii',
    encodingVal: encodingsMap.ascii,
    byteLength: (string) => string.length,
    write: (buf, string, offset, len) => buf.asciiWrite(string, offset, len),
    slice: (buf, start, end) => buf.asciiSlice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfBuffer(buf,
                    fromStringFast(val, encodingOps.ascii),
                    byteOffset,
                    encodingsMap.ascii,
                    dir)
  },
  base64: {
    encoding: 'base64',
    encodingVal: encodingsMap.base64,
    byteLength: (string) => base64ByteLength(string, string.length),
    write: (buf, string, offset, len) => buf.base64Write(string, offset, len),
    slice: (buf, start, end) => buf.base64Slice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfBuffer(buf,
                    fromStringFast(val, encodingOps.base64),
                    byteOffset,
                    encodingsMap.base64,
                    dir)
  },
  hex: {
    encoding: 'hex',
    encodingVal: encodingsMap.hex,
    byteLength: (string) => string.length >>> 1,
    write: (buf, string, offset, len) => buf.hexWrite(string, offset, len),
    slice: (buf, start, end) => buf.hexSlice(start, end),
    indexOf: (buf, val, byteOffset, dir) =>
      indexOfBuffer(buf,
                    fromStringFast(val, encodingOps.hex),
                    byteOffset,
                    encodingsMap.hex,
                    dir)
  }
};
function getEncodingOps(encoding) {
  encoding += '';
  switch (encoding.length) {
    case 4:
      if (encoding === 'utf8') return encodingOps.utf8;
      if (encoding === 'ucs2') return encodingOps.ucs2;
      encoding = StringPrototypeToLowerCase(encoding);
      if (encoding === 'utf8') return encodingOps.utf8;
      if (encoding === 'ucs2') return encodingOps.ucs2;
      break;
    case 5:
      if (encoding === 'utf-8') return encodingOps.utf8;
      if (encoding === 'ascii') return encodingOps.ascii;
      if (encoding === 'ucs-2') return encodingOps.ucs2;
      encoding = StringPrototypeToLowerCase(encoding);
      if (encoding === 'utf-8') return encodingOps.utf8;
      if (encoding === 'ascii') return encodingOps.ascii;
      if (encoding === 'ucs-2') return encodingOps.ucs2;
      break;
    case 7:
      if (encoding === 'utf16le' ||
          StringPrototypeToLowerCase(encoding) === 'utf16le')
        return encodingOps.utf16le;
      break;
    case 8:
      if (encoding === 'utf-16le' ||
          StringPrototypeToLowerCase(encoding) === 'utf-16le')
        return encodingOps.utf16le;
      break;
    case 6:
      if (encoding === 'latin1' || encoding === 'binary')
        return encodingOps.latin1;
      if (encoding === 'base64') return encodingOps.base64;
      encoding = StringPrototypeToLowerCase(encoding);
      if (encoding === 'latin1' || encoding === 'binary')
        return encodingOps.latin1;
      if (encoding === 'base64') return encodingOps.base64;
      break;
    case 3:
      if (encoding === 'hex' || StringPrototypeToLowerCase(encoding) === 'hex')
        return encodingOps.hex;
      break;
  }
}
Nach dem Login kopieren

Zusammenfassung

Die kleinste Einheit zum Speichern von Daten in einem Computer ist Bit, aber die kleinste Einheit zum Speichern von Informationen ist Byte. Basierend auf der Zuordnungsbeziehung zwischen Codierung und Zeichen werden verschiedene Zeichensätze implementiert, einschließlich ASCII und ISO , gbk usw. und die Internationale Organisation für Normung haben Unicode zur Einbeziehung aller Zeichen vorgeschlagen. Es gibt mehrere Unicode-Implementierungslösungen: utf-8, utf-16, utf-24. Sie verwenden unterschiedliche Anzahlen von Bytes zum Speichern von Zeichen. Unter diesen hat utf-8 eine variable Länge und das kleinste Speichervolumen und ist daher weit verbreitet.

Node.js speichert Binärdaten über Buffer, und wenn Sie sie in eine Zeichenfolge konvertieren, müssen Sie ein Codierungsschema angeben. Dieses Codierungsschema umfasst nicht nur Zeichensätze (Zeichensatz), sondern unterstützt auch Hex- und Base64-Schemas, einschließlich:

utf8, ucs2, utf16le, latin1, ascii, base64, hex

Wir haben uns den Node.js-Quellcode der Codierung angesehen und festgestellt, dass jedes Codierungsschema eine Reihe von APIs implementiert, was eine polymorphe Idee ist.

Codierung ist ein Konzept, auf das man beim Erlernen von Node.js häufig stößt. Die Codierung von Node.js umfasst nicht nur Zeichensätze. Ich hoffe, dieser Artikel kann jedem helfen, Codierung und Zeichensätze zu verstehen.

Weitere Kenntnisse zum Thema Programmierung finden Sie unter: Einführung in die Programmierung! !

Das obige ist der detaillierte Inhalt vonLassen Sie uns über die Codierung im Node.js-Puffer sprechen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

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

Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

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!

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

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.

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

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?

Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Nov 16, 2022 pm 08:34 PM

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!

Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Nov 29, 2022 pm 08:44 PM

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

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

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!

Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Feb 08, 2023 am 10:09 AM

Der Grund, warum der Knoten den Befehl npm nicht verwenden kann, liegt darin, dass die Umgebungsvariablen nicht richtig konfiguriert sind. Die Lösung ist: 1. Öffnen Sie „Systemeigenschaften“ 2. Suchen Sie nach „Umgebungsvariablen“ -> „Systemvariablen“ und bearbeiten Sie dann die Umgebung Variablen; 3. Suchen Sie den Speicherort des NodeJS-Ordners. 4. Klicken Sie auf „OK“.

See all articles