Node.js est un environnement d'exécution JavaScript basé sur un modèle d'E/S non bloquant et piloté par les événements, qui est souvent utilisé pour créer des serveurs réseau hautes performances. Dans Node.js, nous pouvons utiliser la méthode pipe pour gérer le flux de données. Cet article présentera les connaissances pertinentes sur pipe dans Node.js.
Dans Node.js, pipe est une méthode très importante qui peut transférer des données d'un flux lisible vers un flux inscriptible. Il s'agit d'un connecteur de flux qui peut envoyer automatiquement des données d'un flux lisible à un flux inscriptible, simplifiant ainsi la complexité de la transmission des données.
la syntaxe de la méthode pipe est la suivante :
readable.pipe(destination[, options])
où, lisible est un flux lisible (tel qu'un flux de fichier, un flux réseau, etc.), et la destination est un flux inscriptible (tel qu'un flux de fichier, flux réseau, etc.) ), options est un objet d'options, comprenant les attributs suivants :
l'implémentation sous-jacente de la méthode pipe est réalisée en surveillant les événements des flux lisibles et inscriptibles. Lorsque le flux lisible émet l'événement data, la méthode pipe transfère automatiquement les données vers le flux inscriptible jusqu'à la fin du flux lisible (appelant la méthode end).
Ce qui suit est un exemple simple d'utilisation de la méthode pipe pour transférer des données d'un flux de fichiers à un autre :
const fs = require('fs'); const readStream = fs.createReadStream('input.txt'); const writeStream = fs.createWriteStream('output.txt'); readStream.pipe(writeStream);
Bien sûr, nous pouvons également chaîner les appels de la méthode pipe. Supposons qu'il y ait maintenant trois fichiers. Nous voulons écrire les données du premier fichier dans le deuxième fichier, puis écrire les données du deuxième fichier dans le troisième fichier. L'implémentation du code est la suivante :
const fs = require('fs'); const readStream1 = fs.createReadStream('input1.txt'); const readStream2 = fs.createReadStream('input2.txt'); const writeStream1 = fs.createWriteStream('output1.txt'); const writeStream2 = fs.createWriteStream('output2.txt'); readStream1.pipe(writeStream1).pipe(writeStream2); readStream2.pipe(writeStream2);
Le code ci-dessus, les données de readStream1 sont d'abord transférées vers writeStream1, puis transférées vers writeStream2 via le canal de writeStream1 tandis que les données de readStream2 sont directement transférées vers writeStream2 ; En d'autres termes, writeStream2 stocke les données de deux fichiers.
Il convient de noter que lors de l'utilisation de la méthode pipe pour transmettre des données, le format de données du flux lisible et du flux inscriptible doit être le même, sinon une erreur sera signalée. Par exemple, nous ne pouvons pas transférer de données d'un flux de fichiers vers une connexion à une base de données car leurs formats de données sont différents.
Par rapport au traitement manuel des données, l'utilisation de la méthode du tuyau présente les avantages suivants :
De plus, la méthode du tuyau dispose également d'un certain mécanisme de tolérance aux pannes. Lorsque le flux inscriptible ne peut pas recevoir de données, la méthode pipe met les données en cache et attend que le flux inscriptible devienne recevable avant de transmettre les données.
Dans Node.js, pipe est une méthode très importante qui peut transférer des données d'un flux lisible vers un flux inscriptible. L'utilisation de la méthode pipe peut simplifier la complexité de la transmission des données, éviter la perte de données ou les fuites de mémoire et dispose d'un certain mécanisme de tolérance aux pannes. Il s'agit d'un moyen important de traiter les flux de données dans Node.js.
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!