


Node.js technique classique Buffer (partage de résumé)
Cet article vous apporte des connaissances pertinentes sur Buffer dans nodejs Dans Node.js, la classe Buffer est une bibliothèque de base publiée avec le noyau Node. La bibliothèque Buffer apporte une méthode de stockage primitive aux méthodes de données Node.js, je l'espère. sera utile à tout le monde.
Le langage JavaScript lui-même n'a que des types de données chaîne, pas des types de données binaires.
Mais lors du traitement de flux comme TCP ou de flux de fichiers, des données binaires doivent être utilisées. Par conséquent, dans Node.js, une classe Buffer est définie, qui est utilisée pour créer une zone tampon spécifiquement pour stocker les données binaires.
Dans Node.js, la classe Buffer est une bibliothèque principale publiée avec le noyau Node. La bibliothèque Buffer apporte une méthode de stockage de données brutes à Node.js, permettant à Node.js de traiter des données binaires. Chaque fois que vous avez besoin de traiter des données déplacées lors d'opérations d'E/S dans Node.js, il est possible d'utiliser la bibliothèque Buffer. .
Les données originales sont stockées dans une instance de la classe Buffer.
Un Buffer est similaire à un tableau d'entiers, mais il correspond à un morceau de mémoire brute en dehors de la mémoire tas V8.
Créer la classe Buffer
La classe Node Buffer peut être créée de différentes manières.
Méthode 1
Créer une instance Buffer d'une longueur de 10 octets :
var buf = new Buffer(10);
Méthode 2
Créer une instance Buffer à partir du tableau donné :
var buf = new Buffer([10, 20, 30, 40, 50]);
Méthode 3
Passez une chaîne Créer une instance Buffer :
var buf = new Buffer("bianchengsanmei", "utf-8");
utf-8 est l'encodage par défaut, et il prend également en charge les encodages suivants : "ascii", "utf8", "utf16le", "ucs2", "base64" et "hex".
Write buffer
Syntaxe
La syntaxe d'écriture du tampon Node est la suivante :
buf.write(string[, offset[, length]][, encoding])
Paramètres
Les paramètres sont décrits comme suit :
- string - la chaîne écrite dans le tampon.
- offset - La valeur d'index à laquelle le tampon commence à être écrit, la valeur par défaut est 0 .
- length - Nombre d'octets écrits, par défaut buffer.length
- encoding - Encodage utilisé. La valeur par défaut est 'utf8' .
Valeur de retour
Renvoie la taille réelle écrite. Si l'espace tampon est insuffisant, seule une partie de la chaîne sera écrite.
Instance
buf = new Buffer(256);len = buf.write("bi");len = buf.write("bianchengsanmei"); console.log("写入字节数 : "+ len);
Exécutez le code ci-dessus, le résultat de sortie est :
$node main.js 写入字节数 : 15
Lire les données du tampon
Syntaxe
La syntaxe de lecture des données du tampon de nœud est la suivante :
buf.toString([encoding[,start[,end]]])
Paramètres
Les paramètres sont décrits comme suit :
encoding - l'encodage utilisé. La valeur par défaut est 'utf8' .
start - Spécifie la position de l'index pour commencer la lecture, la valeur par défaut est 0.
end - position de fin, par défaut à la fin du tampon.
Valeur de retour
Décodez les données du tampon et renvoyez une chaîne en utilisant l'encodage spécifié.
Instance
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
Exécutez le code ci-dessus, le résultat de sortie est :
$ node main.js abcdefghijklmnopqrstuvwxyz abcde abcde abcde
Convert Buffer en objet JSON
Syntaxe
Le format de syntaxe de fonction pour convertir Node Buffer en objet JSON est le suivant :
buf.toJSON()
Return La valeur
renvoie un objet JSON.
Instance
var buf = new Buffer('bianchengsanmei'); var json = buf.toJSON(buf); console.log(json);
Exécutez le code ci-dessus, le résultat de sortie est :
{ type: 'Buffer', data: [ 119, 119, 119, 46, 119, 51, 99, 115, 99, 104, 111, 111, 108, 46, 99, 110 ] }
Buffer merge
Syntaxe
Node La syntaxe de la fusion de tampon est la suivante :
Buffer.concat(list[, totalLength])
Parameters
Les paramètres sont décrits comme suit :
- list - Liste de tableaux d'objets Buffer utilisés pour la fusion.
- totalLength - Spécifie la longueur totale des objets Buffer fusionnés.
Valeur de retour
Renvoie un nouvel objet Buffer qui combine plusieurs membres.
Instance
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());
Exécutez le code ci-dessus, le résultat de sortie est :
buffer3 内容: 编程三昧 bianchengsanmei
Comparaison de tampon
Syntaxe
La syntaxe de la fonction de comparaison de tampon de nœud est la suivante, cette méthode a été introduite dans Node.js v0 Version .12.2 :
buf.compare(otherBuffer);
parameters
les paramètres sont décrits comme suit :
- otherBuffer - un autre objet Buffer comparé à l'objet buf.
Return Value
Renvoie un nombre indiquant que buf est avant, après ou identique à otherBuffer.
Instance
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 + "之后");}
Exécutez le code ci-dessus, le résultat de sortie est :
ABC在ABCD之前
Copy buffer
Syntaxe
La syntaxe de copie du tampon de nœud est la suivante :
buf.copy(target[, targetStart[, sourceStart[, sourceEnd]]])
Parameters
Les paramètres sont décrits comme suit :
- targetBuffer - l'objet Buffer à copier.
- targetStart - nombre, facultatif, par défaut : 0
- sourceStart - nombre, facultatif, par défaut : 0
- sourceEnd - nombre, facultatif, par défaut : buffer.length
Valeur de retour
Aucune valeur de retour.
Instance
var buffer1 = new Buffer('ABC'); // 拷贝一个缓冲区var buffer2 = new Buffer(3); buffer1.copy(buffer2); console.log("buffer2 content: " + buffer2.toString());
Exécuter le code ci-dessus, le résultat de sortie est:
rbuffer2 content: ABC
buffer Clipping
Node tampon La syntaxe est la suivante:
buf.slice([start[, end]])
Parameters
Les paramètres sont décrits comme suit:
- 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 教程!!
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Le service Node construit sur une base non bloquante et piloté par les événements présente l'avantage d'une faible consommation de mémoire et est très adapté à la gestion de requêtes réseau massives. Dans le contexte de demandes massives, les questions liées au « contrôle de la mémoire » doivent être prises en compte. 1. Le mécanisme de récupération de place du V8 et les limitations de mémoire Js sont contrôlés par la machine de récupération de place

Cet article vous donnera une compréhension approfondie de la mémoire et du garbage collector (GC) du moteur NodeJS V8. J'espère qu'il vous sera utile !

Le choix d'une image Docker pour Node peut sembler trivial, mais la taille et les vulnérabilités potentielles de l'image peuvent avoir un impact significatif sur votre processus CI/CD et votre sécurité. Alors, comment choisir la meilleure image Docker Node.js ?

Le module de fichiers est une encapsulation des opérations de fichiers sous-jacentes, telles que l'ajout de lecture/écriture/ouverture/fermeture/suppression de fichiers, etc. La plus grande caractéristique du module de fichiers est que toutes les méthodes fournissent deux versions de **synchrone** et ** asynchrone**, with Les méthodes avec le suffixe sync sont toutes des méthodes de synchronisation, et celles qui n'en ont pas sont toutes des méthodes hétérogènes.

Node 19 est officiellement publié. Cet article vous donnera une explication détaillée des 6 fonctionnalités majeures de Node.js 19. J'espère qu'il vous sera utile !

Comment Node.js fait-il le GC (garbage collection) ? L’article suivant vous guidera à travers cela.

La boucle d'événements est un élément fondamental de Node.js et permet une programmation asynchrone en garantissant que le thread principal n'est pas bloqué. Comprendre la boucle d'événements est crucial pour créer des applications efficaces. L'article suivant vous donnera une compréhension approfondie de la boucle d'événements dans Node. J'espère qu'il vous sera utile !

La raison pour laquelle le nœud ne peut pas utiliser la commande npm est que les variables d'environnement ne sont pas configurées correctement. La solution est la suivante : 1. Ouvrez "Propriétés système" ; 2. Recherchez "Variables d'environnement" -> "Variables système", puis modifiez l'environnement. variables ; 3. Recherchez l'emplacement du dossier nodejs ; 4. Cliquez sur "OK".
