Maison > interface Web > js tutoriel > Un examen plus approfondi des tampons dans Node.js

Un examen plus approfondi des tampons dans Node.js

青灯夜游
Libérer: 2022-02-17 10:42:33
avant
2345 Les gens l'ont consulté

Cet article vous donnera une compréhension approfondie de Buffer dans Node.js Il présentera différentes façons de créer la classe Buffer, les méthodes d'écriture dans les tampons, etc. J'espère qu'il vous sera utile !

Un examen plus approfondi des tampons dans Node.js

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);
Copier après la connexion

Méthode 2

Créer une instance Buffer à partir du tableau donné :

var buf = new Buffer([10, 20, 30, 40, 50]);
Copier après la connexion

Méthode 3

Passez une chaîne Créer une instance Buffer :

var buf = new Buffer("bianchengsanmei", "utf-8");
Copier après la connexion

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])
Copier après la connexion

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);
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

$node main.js
写入字节数 : 15
Copier après la connexion

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]]])
Copier après la connexion

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(&#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
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

$ node main.js
abcdefghijklmnopqrstuvwxyz
abcde
abcde
abcde
Copier après la connexion

Convert Buffer en objet JSON

Syntaxe

Le format de syntaxe de fonction pour convertir Node Buffer en objet JSON est le suivant :

buf.toJSON()
Copier après la connexion

Return La valeur

renvoie un objet JSON.

Instance

var buf = new Buffer(&#39;bianchengsanmei&#39;);
var json = buf.toJSON(buf);
 
console.log(json);
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

{
  type: &#39;Buffer&#39;,
  data: [
     98, 105, 97, 110, 99, 104, 101, 110, 103, 115, 97, 110, 109, 101, 105
  ]
}
Copier après la connexion

Buffer merge

Syntaxe

Node La syntaxe de la fusion de tampon est la suivante :

Buffer.concat(list[, totalLength])
Copier après la connexion

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(&#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());
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

buffer3 内容: 编程三昧 bianchengsanmei
Copier après la connexion

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);
Copier après la connexion

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(&#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 + "之后");
}
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

ABC在ABCD之前
Copier après la connexion

Copy buffer

Syntaxe

La syntaxe de copie du tampon de nœud est la suivante :

buf.copy(target[, targetStart[, sourceStart[, sourceEnd]]])
Copier après la connexion

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.

Exemple

var buffer1 = new Buffer(&#39;ABC&#39;);
// 拷贝一个缓冲区
var buffer2 = new Buffer(3);
buffer1.copy(buffer2);
console.log("buffer2 content: " + buffer2.toString());
Copier après la connexion

Exécutez le code ci-dessus, le résultat de sortie est :

buffer2 content: ABC
Copier après la connexion

缓冲区裁剪

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

buf.slice([start[, end]])
Copier après la connexion

参数

参数描述如下:

  • 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());
Copier après la connexion

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

buffer2 content: yo
Copier après la connexion

缓冲区长度

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

buf.length;
Copier après la connexion

返回值

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

实例

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

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

buffer length: 15
Copier après la connexion

~

~本文完,感谢阅读!

更多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!

Étiquettes associées:
source:juejin.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal