Maison >interface Web >Questions et réponses frontales >Node.js technique classique Buffer (partage de résumé)

Node.js technique classique Buffer (partage de résumé)

WBOY
WBOYavant
2022-02-18 17:31:242315parcourir

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.

Node.js technique classique Buffer (partage de résumé)

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:

r
buffer2 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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer